如何根据文章的ID检索文章的SEF链接?
我是这样想的:
$link = get_link(34); // where 34 is the article ID
<a href="<?php echo $link; ?>">Article link</a>
我的代码是这样的(更新与Rikesh代码):
Mysql query: "SELECT id, title, extra_fields FROM xxxxx_k2_items WHERE catid = ".$catid
$n=0; //counter
while($row = mysql_fetch_array($result)){
$titles[$n] = $row['title'];
$links[$n] = JRoute::_(ContentHelperRoute::getArticleRoute($row['id'], $catid));
$n++;
}
好,现在这检索链接,如/joomla/index.php/currentpage?id=4
,其中4是正确的id,但链接不起作用!它转到错误的一页。我的疑问是:您的代码也适用于K2文章?因为我使用的是K2文章,而不是默认的joomla文章。编辑:是的,我已经检查了我的疑问,你的代码通过ID链接到Joomla文章,但我使用的ID是K2文章!注意:我需要SEF链接
你应该包括K2路线
require_once(JPATH_SITE.DS.'components'.DS.'com_k2'.DS.'helpers'.DS.'route.php');
,你应该更新mysql查询和PHP代码,因为你也需要从k2类别表的信息,这里是一个例子
$db = JFactory::getDBO();
$query = '
SELECT
a.id AS id,
a.extra_fields AS extrafields,
a.catid AS catid,
a.title AS title,
a.introtext AS introtext,
a.alias AS alias,
c.alias AS catalias
FROM
#__k2_items AS a
LEFT JOIN #__k2_categories AS c ON ( a.catid = c.id )
WHERE a.published = 1 AND a.catid = '.$catid;
$db->setQuery($query);
$articles = $db->loadObjectList();
$n=0;
foreach ($articles as $article) {
$titles[$n] = $article->title;
$links[$n] = K2HelperRoute::getItemRoute($article->id.':'.urlencode($article->alias),$article->catid.':'.urlencode($article->catalias));
$n++;
}