04
2018
06

WordPress防止评论中添加了恶意代码的解决方法

即使你的博客管理后台的管理员身份被人破解了,一般他也不会同时破解你的网站空间ftp账号,所以他也更改不了你的网站文件,你可以更改WordPress源文件代码过滤评论,这样不管是谁的评论都过滤一遍。打开当前使用的主题目录下的functions.php,在将第一个 <?php 替换成:

代码如下:

<?php

function ludou_code_escape( $incoming_comment ) {

   $incoming_comment = htmlspecialchars($incoming_comment, ENT_QUOTES);

   return $incoming_comment;

}

add_filter( 'comment_text', 'ludou_code_escape' );

add_filter( 'comment_text_rss', 'ludou_code_escape' );  

以上方法是将评论内容中的代码转义,这样浏览器就不解释这部分代码了,代码也不会起任何作用,并且可以直接看到评论中的代码。这么改的好处是可以在评论中展示代码,另外可以看看到底哪些人在评论中添加了恶意代码,点此查看效果。如果你希望去除所有代码标签,只留下文字内容,请将以上代码改成:

代码如下:

<?php

function ludou_code_escape( $incoming_comment ) {

   $incoming_comment = strip_tags($incoming_comment);

   return $incoming_comment;

}

add_filter( 'comment_text', 'ludou_code_escape' );

add_filter( 'comment_text_rss', 'ludou_code_escape' );  

关于strip_tags过滤函数

定义和用法

strip_tags() 函数剥去 HTML、XML 以及 PHP 的标签。

语法

strip_tags(string,allow)参数 描述 

string 必需。规定要检查的字符串。 

allow 可选。规定允许的标签。这些标签不会被删除。 

提示和注释

注释:该函数始终会剥离 HTML 注释。这点无法通过 allow 参数改变。

代码如下:

<?php

echo strip_tags("Hello <b>world!</b>");

?>

输出:

Hello world!

以上内容在WordPress 2.9.2中测试,其他版本就留给你自己去测试了,基本上都差不多!补充一点,WordPress会不会转义评论内容,不仅由WordPress源程序决定,而且可以在主题或插件中控制。

原文链接:https://www.qiquanji.com/post/8035.html

本站声明:网站内容来源于网络,如有侵权,请联系我们,我们将及时处理。

微信扫码关注

更新实时通知

« 上一篇 下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。