今天有网友反馈到他的WordPress网站定时设置发布文章的功能失效。基本上定时的文章发布出去,而会在文章列表中提示发布失败的问题。这个问题以前老蒋也有遇到过,那时候我看到的问题是因为服务器的时间和网站的时间不同步导致的,后来我同步时间就解决问题。
但是这个同学的问题我看到他的网站时间和服务器时间是没有问题的,不清楚他怎么也有这个问题。这里老蒋直接给他安装一个Missed Scheduled Posts插件来解决这个问题。
插件地址:https://wordpress.org/plugins/missed-scheduled-posts-publisher
这个插件在激活安装后是无感知的,我们只需要正常的设置定时即可,不需要单独设置插件。
看到有网友单独将插件中的代码移植到 Functions.php 也是可以实现的,如果我们不想安装插件也可以直接用代码实现。
<?phpif(!function_exists('add_action')){
header('Status 403 Forbidden');header('HTTP/1.0 403 Forbidden');header('HTTP/1.1 403 Forbidden');exit();}
?>
<?php
function wpms_log(){
echo"\n<!--Plugin WP Missed Schedule 2011.0920.2011 Active-->";
}
add_action('wp_head','wpms_log');
add_action('wp_footer','wpms_log')
?>
<?php
define('WPMS_DELAY',5);
define('WPMS_OPTION','wp_missed_schedule');
function wpms_replace(){
delete_option(WPMS_OPTION);
}
register_deactivation_hook(__FILE__,'wpms_replace');
function wpms_init(){
remove_action('publish_future_post','check_and_publish_future_post');
$last=get_option(WPMS_OPTION,false);
if(($last!==false)&&($last>(time()-(WPMS_DELAY*60))))return;
update_option(WPMS_OPTION,time());
global$wpdb;
$scheduledIDs=$wpdb->get_col("SELECT`ID`FROM`{$wpdb->posts}`"."WHERE("."((`post_date`>0)&&(`post_date`<=CURRENT_TIMESTAMP()))OR"."((`post_date_gmt`>0)&&(`post_date_gmt`<=UTC_TIMESTAMP()))".")AND`post_status`='future'LIMIT 0,5");
if(!count($scheduledIDs))return;
foreach($scheduledIDs as$scheduledID){if(!$scheduledID)continue;
wp_publish_post($scheduledID);}
}
add_action('init','wpms_init',0)
?>
我们试试看吧,本来还有其他插件的发现以前那用的不更新,所以就不分享了。