建站教程

建站教程

Products

当前位置:首页 > 建站教程 >

WordPress上的PHP Everywhere插件曝出三个高危RCE漏洞(如何不用wordpress插件显示文章浏览统计)

GG网络技术分享 2025-03-18 16:14 1


WordPress上的PHP Everywhere插件曝出三个高危RCE漏洞

Bleeping Computer 报道称:安全研究人员在 WordPress 的“PHP Everywhere”插件中发现了三个严重的远程代码执行(RCE)漏洞,导致全球超过 3 万个使用该插件的网站都受到了影响。据悉,该插件旨在方便管理员在页面、帖子、侧边栏、或任何 Gutenberg 块中插入 PHP 代码,并借此来显示基于评估的 PHP 表达式的动态内容。

Wordfence 安全分析师指出,CVSS v3 评分高达 9.9 的这三个漏洞,可被贡献着或订阅者所利用,且波及 2.0.3 及以下的所有 WordPress 版本。

首先是 CVE-2022-24663:

其次是 CVE-2022-24664:

然后是 CVE-2022-24665:

尽管后两个漏洞因需要贡献者的权限级别而不那么容易被利用,但首个漏洞还是让业界感到惊诧不已。

截图(来自:Wordfence)

在 2022 年 1 月 4 日发现了上述漏洞字后,Wordfence 团队很快就向 PHP Everywhere 作者通报了此事。

尴尬的是,尽管开发者行动迅速,但网站管理员普遍不怎么会定期更新其 WordPress 网站和插件。

有鉴于此,考虑到三个 RCE 漏洞的严重性,我们在此强烈建议所有 PHP Everywhere 用户确保其已升级到最新可用的 3.0.0 版本。

如何不用wordpress插件显示文章浏览统计

wordpress无插件显示文章浏览数,附原理说明,网上关于这方面的文章很多了,但是如果不了解下其中原理,难免有些不安,生怕代码有什么漏洞,影响网站的正常访问。下面就来解释一下其中的原理,代码已经在wordpress 3.4.1版本上测试通过

增加文章浏览数

wordpress本身不带文章浏览数的统计功能,所以要先将文章浏览数记录起来,才能在显示文章的时候读取到浏览数。wordpress的数据库中文章表是wp_posts,其中没有浏览次数的字段,如果自己加字段改动就大了。比较好的办法就是将数据记录在wp_postmeta这个表中,这个表就是用来记录一些文章扩展数据的。实现代码如下:

代码如下:

/**

* 设置文章的浏览次数

*

* @param int $postID 文章编号

*/

function setPostViews($postID) {

$count_key = \'post_views_count\';

$count = get_post_meta($postID, $count_key, true);

if ($count == \'\') {

add_post_meta($postID, $count_key, \'1\');

} else {

$count++;

update_post_meta($postID, $count_key, $count);

}

}

代码的流程就是先从wp_postmeta获取文章的浏览数,然后进行判断:如果没有获取到则增加文章浏览数的数据,初始值设置为1;否则就将浏览数加1,更新文章浏览数。

最后只需将这段代码复制到主题的funtions.php文件中,并在文章页面(single.php)的主循环内调用即可,调用代码如下:

代码如下:

<?php setPostViews(get_the_ID()); ?>

如何不用wordpress插件显示文章浏览统计 (https://www.wpmee.com/) WordPress使用教程 第1张

获取文章浏览数

文章浏览数记录之后就能读取到了。代码如下:

代码如下:

function getPostViews($postID){

$count_key = \'post_views_count\';

$count = get_post_meta($postID, $count_key, true);

if($count==\'\'){

return 1;

}

return $count;

}

代码的流程就是从wp_postmeta获取文章的浏览数,如果没有就返回1,否则就返回浏览数。

将这段代码复制到主题的funtions.php文件中,在需要的地方调用这个方法就可以了。

小结

网上流行的版本有调用delete_post_meta,仔细查看代码发现没有什么必要。另外还有一个postviews插件也能实现类似功能,不过从官网来看只兼容到wordpress 3.3.2版本。

以上就是如何不用wordpress插件显示文章浏览统计功能的详细内容,更多请关注网站的其它相关文章!

标签:

提交需求或反馈

Demand feedback