1

我正在尝试将 PHPBB3 论坛的论坛提要集成到外部首页中。

为此,我使用了 phpbbwiki 中的示例: 这是代码

我的问题是,这仅在用户已在论坛上进行身份验证时才有效,但我希望用户看到对访客用户开放的主题,而不是 PHPBB 默认(空白)页面。

在这种情况下,我使用 ajax 以 JSON 格式返回主题,但这对我的问题来说并不重要。

很高兴知道这是否可以在 PHPBB 能够提供的范围内实现,以及如果这是一个更复杂的问题,从哪里开始寻找。

如果这对你们中的一些人来说是一件简单的事情,我将不胜感激。

谢谢!

更新

没有创建用于检索帖子的 SQL 语句,因为用户似乎没有读取权限。失败的条件是 (function: create_where_clauses) :

// If the type is forum, do the check to make sure the user has read permissions
else if( $type == 'forum_id' && $auth->acl_get('f_read', $id_check) )

其中 id_check 是当前的 forum_id。

这是用户数据对象的一部分:

  ["user_id"]  => string(1) "1"
  ["user_type"]=> string(1) "2"
  ["group_id"] => string(1) "1"

此用户在 GUESTS 组中,默认类型为 IGNORE。我尝试将 user_type 设置为 0=NORMAL - 无济于事。

作为 PHPBB3 论坛的普通访问者,我可以阅读所有开放的论坛,我想知道为什么这个普通的访客用户无法访问论坛。

更新和解决

我要感谢您的回答,使我再次走上正轨。当我犯的最初的错误只是一个愚蠢的复制/粘贴问题时,我会无休止地寻找 PHPBBs 用户管理深处的解决方案......

$forum_id = array(2, 5);
$forum_id_where = create_where_clauses($forum_id, 'forum');

$topic_id = array(20, 50);
$topic_id_where = create_where_clauses($topic_id, 'topic');

这两行取自教程,在尝试从“所有”论坛和主题中检索数据时仍然存在。顺便说一句,那些论坛 ID 对注册用户开放而对未经身份验证的用户关闭。当解除上述内容限制时,脚本再次按原样执行。

再说一遍——特别感谢安迪。

4

1 回答 1

1

空白页是因为您的目录中没有external_body.html文件style/prosilver/templates

一个非常基本的external_body.html看起来像这样。显然,您必须将其集成到您的主页主题中。

<!-- BEGIN announcements -->
Title: {announcements.TOPIC_TITLE}<br />
Post author: {announcements.POST_AUTHOR}<br />
Post date: {announcements.POST_DATE}<br />
Last post text: {announcements.POST_TEXT}<br />
Post link: {announcements.POST_LINK}
<!-- END announcements -->

然后,使用 phpBB.com MOD 团队的 battye 提供的文件,并将其放在您论坛的根目录中,您可以显示最近的帖子。

external_page.php

<?php
/*
* Description: example file for displaying latest posts and topics
* by battye (for phpBB.com MOD Team)
* September 29, 2009
* Modified for StackOverflow Question: http://stackoverflow.com/questions/14723578/phpbb3-forum-feed-on-external-page-for-non-authenticated-users
*/

define('IN_PHPBB', true);
$phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './';
$phpEx = substr(strrchr(__FILE__, '.'), 1);
include($phpbb_root_path . 'common.' . $phpEx);
include($phpbb_root_path . 'includes/bbcode.' . $phpEx);
include($phpbb_root_path . 'includes/functions_display.' . $phpEx);

// Start session management
$user->session_begin();
$auth->acl($user->data);
$user->setup('viewforum');

$search_limit = 5;

// ----- Change between HERE -----
$posts_ary = array(
        'SELECT'    => 'p.*, t.*, u.username, u.user_colour',

        'FROM'      => array(
            POSTS_TABLE     => 'p',
        ),

        'LEFT_JOIN' => array(
            array(
                'FROM'  => array(USERS_TABLE => 'u'),
                'ON'    => 'u.user_id = p.poster_id'
            ),
            array(
                'FROM'  => array(TOPICS_TABLE => 't'),
                'ON'    => 'p.topic_id = t.topic_id'
            ),
        ),

        'WHERE'     => $db->sql_in_set('t.forum_id', array_keys($auth->acl_getf('f_read', true))) . '
                        AND t.topic_status <> ' . ITEM_MOVED . '
                         AND t.topic_approved = 1',

        'ORDER_BY'  => 'p.post_id DESC',
    );

    $posts = $db->sql_build_query('SELECT', $posts_ary);

    $posts_result = $db->sql_query_limit($posts, $search_limit);

      while( $posts_row = $db->sql_fetchrow($posts_result) )
      {
         $topic_title       = $posts_row['topic_title'];
         $post_author       = get_username_string('full', $posts_row['poster_id'], $posts_row['username'], $posts_row['user_colour']);
         $post_date          = $user->format_date($posts_row['post_time']);
         $post_link       = append_sid("{$phpbb_root_path}viewtopic.$phpEx", "p=" . $posts_row['post_id'] . "#p" . $posts_row['post_id']);

         $post_text = nl2br($posts_row['post_text']);

         $bbcode = new bbcode(base64_encode($bbcode_bitfield));         
         $bbcode->bbcode_second_pass($post_text, $posts_row['bbcode_uid'], $posts_row['bbcode_bitfield']);

         $post_text = smiley_text($post_text);

         $template->assign_block_vars('announcements', array(
         'TOPIC_TITLE'       => censor_text($topic_title),
         'POST_AUTHOR'       => $post_author,
         'POST_DATE'       => $post_date,
         'POST_LINK'       => $post_link,
         'POST_TEXT'         => censor_text($post_text),
         ));
      }
// --- and HERE ---

page_header('External page');

    $template->set_filenames(array(
        'body' => 'external_body.html'
    ));

    page_footer();
?>

如果您不想在论坛的根目录中使用它,则需要修改此行以使用适当的路径指向您的论坛的根目录:

$phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './';

指示在何处更改代码块的两行是显示内容的核心。上面,我从您提供的链接中发布了示例 4 。替换其他示例中的整个代码块也可以。

最后,您可能需要在更改模板时从 ACP 中清除缓存。

于 2013-02-15T20:50:45.323 回答