严格标准:非静态方法 StreamComment::getCommentsHTML() 不应静态调用,假设 $this 来自不兼容的上下文 [英] Strict Standards: Non-static method StreamComment::getCommentsHTML() should not be called statically, assuming $this from incompatible context

查看:13
本文介绍了严格标准:非静态方法 StreamComment::getCommentsHTML() 不应静态调用,假设 $this 来自不兼容的上下文的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用 Offiria(基于 joomla 的社交网络脚本),当我单击显示所有评论"链接以查看链接下的所有已发布评论时,我在第一条评论正上方收到以下错误.该函数可以工作,因此所有评论都展开,我可以看到所有评论,但错误也出现在那里.

I am using Offiria (joomla based social networking script) and when I click on the link "Show All Comments" to see all posted comments under a link, I get the following error right above the first comments. The function works so all comments expand and I can see them all but the error sits there as well.

严格标准:非静态方法StreamComment::getCommentsHTML()不应静态调用,假设 $this 来自不兼容C:Program 中的上下文FilesAmppswwwoffiriacomponentscom_streamcontrollerscomment.php第 31 行

Strict Standards: Non-static method StreamComment::getCommentsHTML() should not be called statically, assuming $this from incompatible context in C:Program FilesAmppswwwoffiriacomponentscom_streamcontrollerscomment.php on line 31

这是comment.php文件中的第31行:

Here is the line 31 in comment.php file:

public function  showall()
{
    $stream_id = JRequest::getVar('message_id');
    $html = StreamComment::getCommentsHTML($stream_id);
    header('Content-Type: text/html; charset=UTF-8');
    echo $html;
    exit;
}

我已尝试禁用 php.ini 中的所有错误报告选项,但错误不断出现.我也尝试将上述代码更改为public static function showall()",但我收到一个错误消息:严格标准:不应静态调用非静态方法 StreamComment::getCommentsHTML().

I have tried disabling all error reporting options in my php.ini but the error keeps coming up. I have also tried changing the above code to "public static function showall()" but I get an error that Strict Standards: Non-static method StreamComment::getCommentsHTML() should not be called statically.

如果您对此有任何帮助,我将不胜感激.

I would appreciate any help with this in advance.

这里是完整的comment.php

<?php
/**
 * @version     1.0.0
 * @package     com_administrator
 * @copyright   Copyright (C) 2011 - 2013 Slashes & Dots Sdn Bhd. All rights reserved.
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 * @author      Offiria Team
 */

// No direct access.
defined('_JEXEC') or die;

jimport('joomla.application.controller');

class StreamControllerComment extends JController
{
    /**
     *
     */     
    public function display($cachable = false, $urlparams = false){
        parent::display( null );
    }


    /**
     *  Return HTML of all
     */     
    /**public function  showall()
    {
        $stream_id = JRequest::getVar('message_id');
        $html = StreamComment::getCommentsHTML($stream_id);
        header('Content-Type: text/html; charset=UTF-8');
        echo $html;
        exit;
    }

    /**
     *  Add message
     */                            
    public function add()
    {
        $user   = JXFactory::getUser();

        // Store stream
        $comment    = JTable::getInstance( 'Comment' , 'StreamTable' );
        $message    = JTable::getInstance( 'Stream' , 'StreamTable' );
        $message->load(JRequest::getVar('stream_id'));
        $user_id = JRequest::getVar('anon', false) ? JUserHelper::getUserId('anon') : $user->id;

        // People need to be able to read the message to add comment
        if( !$user->authorise('stream.message.read', $message) ){
            // No reason this code would ever get here!
            exit;
        }

        $comment->bind( JRequest::get('POST', JREQUEST_ALLOWRAW) );

        $comment->raw = json_encode( JRequest::get('POST', JREQUEST_ALLOWRAW) );
        $comment->user_id = $user_id;
        $comment->group_id = $message->group_id;            
        $comment->store();

        // Update group stats, if it is a group message
        if( !empty($comment->group_id)){
            $group  = JTable::getInstance( 'Group' , 'StreamTable' );
            $group->load($comment->group_id);
            $group->setParam('last_comment', $comment->id);
            $group->store();
        }

        // Trigger Notification 
        StreamNotification::trigger( 'profile_post_comment', $comment );

        // If the updated date is set further than the current date, it is a pinned stream item and shouldn't be updated
        $now        = new JDate();
        $updated    = new JDate($message->updated);
        $preventUpdate = ($updated->toUnix() > $now->toUnix()); // Check pinned item status too? For now... naa

        // Update stream stats. Recalculate the count
        $this->_recalculateCommentCount($comment->stream_id, $preventUpdate);

        // Get the HTML code to append
        $tmpl = new StreamTemplate();
        header('Content-Type: text/html; charset=UTF-8');
        echo $tmpl->set('comment', $comment)->fetch('comment.item');
        exit;
    }

    /**
     * Delete a message
     */
    public function delete(){
        $my = JXFactory::getUser();
        $id = JRequest::getVar('comment_id');
        $oldComment = '';

        $comment    = JTable::getInstance( 'Comment' , 'StreamTable' );
        $comment->load($id);

        if( !$my->authorise('stream.comment.delete', $comment) ){
            // No reason this code would ever get here!
            exit;
        }
        $oldComment = $comment->comment;
        $comment->delete();
        $this->_recalculateCommentCount($comment->stream_id, true);

        // Send back the original comment if it is the last one
        $data = array();
        $data['comment'] = $oldComment;

        header('Content-Type: text/json');
        echo json_encode($data);
        exit;
    }

    private function _recalculateCommentCount($message_id, $preventUpdate = false)
    {
        // Update stream stats. Recalculate the count
        $model = StreamFactory::getModel('stream');
        $stream = JTable::getInstance('Stream', 'StreamTable');
        $stream->load( $message_id ) ;
        $stream->setParam('comment_count', $model->countComments(array('stream_id' => $stream->id)));
        $stream->store( $preventUpdate );
    }

    /**
     *  Like a comment
     */
    public function like()
    {
        $user = JXFactory::getUser();
        $comment_id = JRequest::getVar('comment_id');

        $comment = JTable::getInstance('Comment', 'StreamTable');
        $comment->load($comment_id);

        $comment->like();
        $comment->store(true);

        $data = array();
        $data['label'] = JText::_('COM_STREAM_UNLIKE_LABEL');
        $data['count'] = $comment->getLikeCount();

        header('Content-Type: text/json');
        echo json_encode($data);
        exit;
    }

    /**
     * Unlike a comment
     */
    public function unlike()
    {
        $user = JXFactory::getUser();
        $comment_id = JRequest::getVar('comment_id');

        $comment = JTable::getInstance('Comment', 'StreamTable');
        $comment->load($comment_id);
        $comment->unlike();

        $comment->store(true);

        $data = array();
        $data['label'] = JText::_('COM_STREAM_LIKE_LABEL');
        $data['count'] = $comment->getLikeCount();

        header('Content-Type: text/json');
        echo json_encode($data);
        exit;
    }

    /**
     * Get all current likes
     */
    public function showlikes()
    {
        $comment_id = JRequest::getVar('comment_id');
        $comment = JTable::getInstance('Comment', 'StreamTable');
        $comment->load($comment_id);

        $likes = ($comment->likes) ? explode(',', $comment->likes ) : null;
        $likeUsers = array();
        $likesHTML = '';
        if ($likes) {
            foreach ($likes as $key => $val) {
                $likeUsers[] = JXFactory::getUser($val)->name;
            }

            $likesHTML = implode(", ", $likeUsers);
            $likesHTML = JXString::isPlural(count($likeUsers)) ? JText::sprintf('COM_STREAM_LIKE_THIS_MANY_LIST', $likesHTML) : JText::sprintf('COM_STREAM_LIKE_THIS_LIST', $likesHTML);
        }

        $data['likes'] = $likesHTML;

        header('Content-Type: text/json');
        echo json_encode($data);
        exit;
    }
}

推荐答案

这里发生的事情是这个函数被静态调用了:

What's happened here is that this function has been called statically:

StreamComment::showall(); // Static Call

但它被定义为非静态方法,这意味着 PHP 期望它像这样被调用:

But it's defined as a non-static method, which means PHP is expecting it to be called like this:

$obj = new StreamComment();
$obj->showall(); // Dynamic Call

如果这是唯一调用此方法的地方,或者它一直被静态调用,您可以通过将方法重新定义为静态来解决此问题:

If this is the only place this method is called, or it's consistently called statically, you can fix this by redefining the method as static:

public static function showall() // Added the "static" keyword
{
    // [..code..]
}

希望这有帮助:) x

这篇关于严格标准:非静态方法 StreamComment::getCommentsHTML() 不应静态调用,假设 $this 来自不兼容的上下文的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆