WordPress禁止版本修订历史,自动保存和自动草稿最新方法汇总

WordPress的版本修订历史(revision)、自动保存(autosave)和自动草稿(auto-draft)功能会非常讨厌的增加文章ID的数字,会造成连续的两篇文章,ID数值可能会相差很多,让我们这些希望文章ID连续的人感到非常不舒服。

网上有很多的教程,但是有的说的不全面,有的说的有问题,我在这里做一个更正汇总。

禁用版本修订历史(revision)和自动保存(autosave):
版本修订历史(revision)是在文章发布后,每次更新时向数据库添加一条版本修订历史记录。这种方式和wiki很像。然而,由于个人博客很少需要保 留版本记录,这个功能显得有些鸡肋。不知为何WordPress不给这样的功能开一个设置选项,可以让用户选择是否开启。
自动保存(autosave)虽然应该存在,但WordPress的处理方式实在有些奇怪,自动保存居然也要占用文章ID,并且默认60s保存一次,这样会造成一篇文章写下来可能会消耗几十个ID,并且在数据库中存入了大量的无用信息。
不过,禁用之后也带来了一个副作用:预览不能使用了,需要手动保存草稿后才行。美中不足吧。

方法一:(未测试)
找到wp-includes/defaut-contants.php文件,修改如下代码:

// 修改前
if ( !defined( 'AUTOSAVE_INTERVAL' ) )
  define( 'AUTOSAVE_INTERVAL', 60 );//这个是自动保存
if ( !defined('WP_POST_REVISIONS') )
  define('WP_POST_REVISIONS', true );//这个是版本修订历史
 
// 修改后
if ( !defined( 'AUTOSAVE_INTERVAL' ) )
  define( 'AUTOSAVE_INTERVAL', false );//禁用自动保存
if ( !defined('WP_POST_REVISIONS') )
  define('WP_POST_REVISIONS', false );//禁用版本修订历史

其中autosave的60为自动保存时间间隔,单位为s,可以修改为更大的数值或修改为false禁用。

这个方法要修改WordPress的原文件,对于主题制作者,如果要添加移除自动保存和修订版本的选项,还是推荐下面的主题functions.php修改方法。

方法二:(测试有效)
上面这一步也可以修改根目录下的wp-config.php文件,在“define(‘WP_DEBUG’, false);”后边添加如下代码:

define('WP_DEBUG', false);
/** Disable autosave and revision */
define( 'AUTOSAVE_INTERVAL', false );
define('WP_POST_REVISIONS', false );

但是版本修订历史最好不要禁用而设置成10小时自动保存一次,即define(‘WP_POST_REVISIONS’, 36000 );,因为修改成false以后造成WordPress报错的一个bug,开启debug可以在编辑文章时看到提醒,编辑一篇文章可不会超过10小时,所 以效果是一样的。
但是,这样并没有完全禁用掉自动保存。还需要修改wp-admin/post-new.php和wp-admin/post.php这两个文件(老版本的 WordPress可能有四个文件“post.php,page.php,post-new.php,page-new.php”,方法还是一样的)。将 这两个文件中的wp_enqueue_script( ‘autosave’ );注释掉,其中post.php还要把前面一行的if语句注释掉,这个是新版本WordPress要注意的,老版本就网上就没说注释掉前面的if,如果不注释掉发布新文章的时候会出错,这一点也是在很多文章中没有提到的。

方法三:(未尝试)
在functions.php的最后php结束标记前加上如下代码:

//移除自动保存
wp_deregister_script('autosave');
//移除修订版本
remove_action('post_updated','wp_save_post_revision' );

这 里移除修订版本的方法不同于网上早期的方法的地方是,’wp_save_post_revision’ 挂载的钩子已经由‘pre_post_updated’变成了‘post_updated’,这个变化貌似是WordPress版本4.0之后,造成了早 期的修改方法失效了,具体见WordPress原文件wp-includes/default-filters.php第265行 (WordPress4.2.2版本)

禁用自动草稿(auto-draft):
自动草稿(auto-draft)是在WordPress3.0之后新增的功能,在点开新建文章后(不确定是否只是这种情况)自动保存的草稿,会被WordPress定期清除,但占据的ID也随之失去。这个功能也没有太大的用处,属于鸡肋功能。

方法一:(测试出错)
禁用自动草稿,可以在wp-admin/includes/post.php中修改代码如下:

// 修改前
if ( $create_in_db ) {
  $post_id = wp_insert_post( array( 'post_title' => __( 'Auto Draft' ), 'post_type' => $post_type, 'post_status' => 'auto-draft' ) );
  $post = get_post( $post_id );
  if ( current_theme_supports( 'post-formats' ) && post_type_supports( $post->post_type, 'post-formats' ) && get_option( 'default_post_format' ) )
    set_post_format( $post, get_option( 'default_post_format' ) );
}

简单解释下这段代码,先是清除七天以前的自动草稿,然后插入一条新草稿,如果你继续写文章并发布,那么这条草稿就被使用了,包括在后台首页有一个快速发布, 也用到了这个。而很诡异的是,如果你后台点了“添加文章”,没有输入任何内容或到别的页面或是关闭了,此时仍然会生成一个自动草稿,而这个草稿,是后台不 可见的,是垃圾数据,隐形的祸害,也是造成文章ID不连续的隐形杀手,之后我会专门介绍清理WordPress垃圾数据和完美解决文章ID不连续问题的办 法。
言归正传,我们直接将上面代码替换成:

// 修改后
if ( $create_in_db ) {
  global $current_user;
  $post = $wpdb->get_row( "SELECT * FROM $wpdb->posts WHERE post_status = 'auto-draft' AND post_type = '$post_type' AND post_author = $current_user->ID ORDER BY ID ASC LIMIT 1" );
  if ( !$post ) {
    $post_id = wp_insert_post( array( 'post_title' => __( 'Auto Draft' ), 'post_type' => $post_type, 'post_status' => 'auto-draft' ) );
    $post = get_post( $post_id );
  }
  if ( current_theme_supports( 'post-formats' ) && post_type_supports( $post->post_type, 'post-formats' ) && get_option( 'default_post_format' ) )
    set_post_format( $post, get_option( 'default_post_format' ) );
}

原理及说明:当数据库中有一条或多条状态为”auto-draft”的自动草稿时,取ID最小的,新文章即使用此条记录。如果没有此种类型的数据,才会新 插入一条数据。并且查询数据时是根据当前的用户来判断,不会出现多用户时出错。这样就可以避免了自动草稿(auto-draft)的冗余垃圾数据。保证了 日志ID的连续性。但最后我要提醒一句,如果你在日志中添加了附件,如图片,那么该图片也会占用一条数据,即一个连续的ID,所以,如果你以ID形式,发 现日志有时候不是连续的ID了,那么,有可能是你日志的附件占用了临近的ID。

方法二:(测试出错)
现在网上很常用的一个禁用自动草稿方法就是在如下代码:

if ( $create_in_db )

前加上:

$create_in_db = false;

这 种方法很方便,也解决了文章发布按钮一闪一闪的问题。貌似很完美,其实还有一个严重的问题,就是你在添加新文章的时候,如果有自定义栏目,字段内容将保存 不了,还会在postmeta表中插入一条无效数据,只有你重新编辑才能保存,所以还是建议采用我的这种方法,可以完美解决,觉得有用的要支持一下哦!

方法三:(测试出错)
打开wp-admin/includes/post.php,查找$create_in_db,如下

$post_id = wp_insert_post( array( 'post_title' => __( 'Auto Draft' ), 'post_type' => $post_type, 'post_status' => 'auto-draft' ) );
$post = get_post( $post_id );

直接注释前2行,加入以下代码,即可关闭WordPress4.1.1的自动草稿功能了,即:

/*
$post_id = wp_insert_post( array( 'post_title' => __( 'Auto Draft' ), 'post_type' => $post_type, 'post_status' => 'auto-draft' ) );
$post = get_post( $post_id );
*/
/* Modified by Lee */
global $current_user,$wpdb;
$post = $wpdb->get_row( "SELECT * FROM $wpdb->posts WHERE post_status = 'auto-draft' AND post_type = '$post_type' AND post_author = $current_user->ID ORDER BY ID ASC LIMIT 1" );
if (!($post) ) {
    $post_id = wp_insert_post( array( 'post_title' => __( 'Auto Draft' ), 'post_type' => $post_type, 'post_status' => 'auto-draft' ) );
    $post = get_post( $post_id );
}
/* End */

还有什么可能没有解决?
除了上述的这些可能造成文章ID不连续的功能外,WordPress还会在上传新的文件、添加导航菜单、添加页面等情况下占用ID,造成文章ID不连续。这种占用没有太好的方法进行解决。
总之,WordPress的结构设计造成了大家极其反感的文章ID不连续问题,WordPress却完全没有修改这种不合理设计的打算。 WordPress加入了一些使用不多意义不大的功能(比如auto-draft),却对于一些常用功能没有默认的支持,只能依靠插件或主题,实在有些古 怪。

PS:我发现我用了上面我测试有效的第二种方法和注释掉了wp_enqueue_script( ‘autosave’ );之后也就禁用了自动草稿的功能呢,你们也可以试试我测试过的方法。我这里汇总的方法包括老版本WordPress和新版本的WordPress的修改方法,有些方法可能不适合,多试几种就好了,总有一种适合你。

参考网址:

WordPress禁止版本修订历史、自动保存和自动草稿

http://www.xp-sem.com/wordpress-disable-revision-auto-draft/

http://www.zhiyanblog.com/wordpress-4-x-continuous-posts-id.html