为了使网站在全国都有一个很好的体验,越来越多的站点选择使用CDN对网站进行加速,这其中就包括很多的Wordpress站点。启用CDN后,WP-PostViews插件无法准确的记录文章的访问数的问题一直困扰着我,WP-PostViews插件默认使用PHP计数,只有在回源访问的时候WP-PostViews插件才会计数。
今日对WP-PostViews插件进行了一番研究,原来这家伙是支持ajax提交的,也就是说CDN对网页进行静态加速后,可以通过ajax提交页面的访问数。但ajax提交是一个隐藏设置项,Wordpress站点必须开启WP_CACHE缓存才能设置。
在Wordpress根目录下找到并打开wp-config.php,在wp-config.php文件中添加:
define(“WP_CACHE”, true);
进入Wordpress后台的WP-PostViews插件设置页面,在设置页面会出现“Use AJAX To Update Views”设置项,选择“Yes”启用Ajax更新WP-PostViews数据统计。
使用CDN后WP-PostViews插件不计数的解决办法
点击“Save Changes”完成设置。此时你打开任何一篇文章在文章源码中看到如下代码即代表Ajax更新WP-PostViews数据统计开启成功(请注意“Count Views From”设置项,如为Guests only,以管理员身份登陆是看不到的)。
/* <![CDATA[ */
var viewsCacheL10n = {“admin_ajax_url”:”https:\/\/www.duoluodeyu.com\/wp-admin\/admin-ajax.php”,”post_id”:”2837″};
/* ]]> */
后续当用户访问CDN缓存的静态页面时,会发起一个如下的请求通知WP-PostViews插件更新数据:
https://www.domain.com/wp-admin/admin-ajax.php?postviews_id=xxxx&action=postviews&_=xxxxxxxxxx
在服务器的访问日志里面也可以看到类似的访问日志。
结论分析:
WP-PostViews插件会去判断WP是否开启了缓存(WP_CACHE),若开启了则使用ajax的计数方式,否则使用php计数方式。如果你使用的是非PHP的缓存机制,比如CDN、Nginx的fastcgi_cache或者proxy_cahe,那么必须在wp-config.php里面开启WP_CACHE,让插件知道你的网站是有缓存机制。
define(“WP_CACHE”, true);