WordPress禁止版本修订历史、自动保存和自动草稿最新方法汇总
提醒:我这里汇总的方法有一些只支持以前老版本的WordPress,对于新版本的WordPress,有些功能是不支持的,所以操作前请做好备份。我的WordPress版本目前是4.3.1,我会在我测试有效的后面注明。
WordPress的版本修订历史(revision)、自动保存(autosave)和自动草稿(auto-draft)功能会非常讨厌的增加文章ID的数字,会造成连续的两篇文章,ID数值可能会相差很多,让我们这些希望文章ID连续的人感到非常不舒服。
网上有很多的教程,但是有的说的不全面,有的说的有问题,我在这里做一个更正汇总。
禁用版本修订历史(revision)和自动保存(autosave):
版本修订历史(revision)是在文章发布后,每次更新时向数据库添加一条版本修订历史记录。这种方式和wiki很像。然而,由于个人博客很少需要保
留版本记录,这个功能显得有些鸡肋。不知为何WordPress不给这样的功能开一个设置选项,可以让用户选择是否开启。
自动保存(autosave)虽然应该存在,但WordPress的处理方式实在有些奇怪,自动保存居然也要占用文章ID,并且默认60s保存一次,这样会造成一篇文章写下来可能会消耗几十个ID,并且在数据库中存入了大量的无用信息。
不过,禁用之后也带来了一个副作用:预览不能使用了,需要手动保存草稿后才行。美中不足吧。
方法一:(未测试)
找到wp-includes/defaut-contants.php文件,修改如下代码:
1
2
3
4
5
6
7
8
9
10
11
|
// 修改前 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);”后边添加如下代码:
1
2
3
4
|
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结束标记前加上如下代码:
1
2
3
4
|
//移除自动保存 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中修改代码如下:
1
2
3
4
5
6
7
|
// 修改前 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不连续问题的办
法。
言归正传,我们直接将上面代码替换成
1
2
3
4
5
6
7
8
9
10
11
|
// 修改后 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。
方法二:(测试出错)
现在网上很常用的一个禁用自动草稿方法就是在如下代码
1
|
if ( $create_in_db ) |
前加上
1
|
$create_in_db = false; |
这
种方法很方便,也解决了文章发布按钮一闪一闪的问题。貌似很完美,其实还有一个严重的问题,就是你在添加新文章的时候,如果有自定义栏目,字段内容将保存
不了,还会在postmeta表中插入一条无效数据,只有你重新编辑才能保存,所以还是建议采用我的这种方法,可以完美解决,觉得有用的要支持一下哦!
方法三:(测试出错)
打开wp-admin/includes/post.php,查找$create_in_db,如下
1
2
|
$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的自动草稿功能了,即:
1
2
3
4
5
6
7
8
9
10
11
12
|
/* $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的修改方法,有些方法可能不适合,多试几种就好了,总有一种适合你。
参考网址:
http://www.pythoner.com/27.html
http://www.xp-sem.com/wordpress-disable-revision-auto-draft/
http://www.zhiyanblog.com/wordpress-4-x-continuous-posts-id.html
WordPress禁止版本修订历史、自动保存和自动草稿最新方法汇总的更多相关文章
- 关于visocode 自动保存时自动添加分号问题
先下载插件: Vueter 打开设置的配置文件,写入一下代码: // //是否需要保存时自动格式化 "editor.formatOnSave": true, //使js 文件保存 ...
- 用汇编语言给XP记事本添加“自动保存”功能 good
[文章标题]: 用汇编语言给XP记事本添加“自动保存”功能 [文章作者]: newjueqi [作者邮箱]:zengjiansheng1@126.com [作者QQ]:190678908 [使用工具] ...
- WordPress 禁用文章修订和自动保存的方法
以下代码亲测并没有效果,不能禁用自动保存 /* 移除自动保存和修订版本 */ remove_action('pre_post_update', 'wp_save_post_revision' ); ...
- 定期清理WordPress的文章修订版本
当WordPress编辑或修改文章时会自动保存生成一个修订版本,默认是每分钟1次.方便恢复早先撰写的版本.不过时间一长就会产生大量的冗余数据,加重服务器负担,拖慢数据加载.当所有发布的文章都已更新到最 ...
- wordpress自动保存远程图片插件 DX-auto-save-images
wordpress自动保存远程图片插件DX-auto-save-images 解决了保存文章就可以自动将远程图片保存到你的服务器上了. 具体操作步骤如下: 1.安装启用wordpress自动保存远程图 ...
- 为什么说JAVA中要慎重使用继承 C# 语言历史版本特性(C# 1.0到C# 8.0汇总) SQL Server事务 事务日志 SQL Server 锁详解 软件架构之 23种设计模式 Oracle与Sqlserver:Order by NULL值介绍 asp.net MVC漏油配置总结
为什么说JAVA中要慎重使用继承 这篇文章的主题并非鼓励不使用继承,而是仅从使用继承带来的问题出发,讨论继承机制不太好的地方,从而在使用时慎重选择,避开可能遇到的坑. JAVA中使用到继承就会有两 ...
- Office__自动保存和恢复
#1.前言 在您埋头辛苦编辑Excel.Word或PPT文档的时候,如果突然发生断电.系统崩溃.意外误操作,本文将以Excel2010为例详细阐述其中自动保存功能的工作机理和恢复文件的访问方法,Exc ...
- DynamicsCRM中的自动保存
DynamicsCRM的自动保存功能 在DynamicsCRM2013开始,引入了自动保存功能. 保存一条记录 在新建一条记录的时候, 你必须在左上角手动点击保存按钮.如下图: 当保存完后,会发现,左 ...
- 关于Microsoft CRM 2013自动保存Autosave功能的10点说明
今天不经意翻看到以前记的笔记发现这个笔记觉得还是应该把它整理记录一下: 关于Microsoft CRM 2013自动保存Autosave功能的10点说明: 1.新建时不会自动保存,需要手动点击保存按钮 ...
随机推荐
- keras初涉笔记【一】
安装keras依赖的库 sudo pip install numpy sudo pip install scipy sudo pip installl pyyaml sudo pipi install ...
- Yii2 Ajax Post 实例及常见错误修正
先贴下我的代码: signup.js$('.reg_verify_pic').click(function(){ var csrfToken = $('meta[name="_csrf-To ...
- 总结JS中string、math、array的常用的方法
JS为每种数据类型都内置很多方法,真的不好记忆,而且有些还容易记混,现整理如下,以便以后查看: 一.String ①charAt()方法用于返回指定索引处的字符.返回的字符是长度为 1 的字符串. 语 ...
- HDU - 2614 dfs
思路:记录当前用的最大时间即刚解决的问题花费的时间,下一个应该做的题的时间必须大于等于刚才的. AC代码 #include <cstdio> #include <cmath> ...
- HDU - 1248 寒冰王座 数学or暴力枚举
思路: 1.暴力枚举每种面值的张数,将可以花光的钱记录下来.每次判断n是否能够用光,能则输出0,不能则向更少金额寻找是否有能够花光的.时间复杂度O(n) 2.350 = 200 + 150,买350的 ...
- poj1011 && uva307 DFS + 剪枝
将木棒从大到小排列,保证每次的选择都是最长可选的木棒. 剪枝: 1 . 如果第 i 根木棒被选择却无法成功拼接,那么后面与其长度相同的也不能选择. 2 . 如果第 cnt + 1 根木棒无法成功拼接, ...
- Springdata mongodb 版本兼容 引起 Error [The 'cursor' option is required, except for aggregate with the explain argument
在Spring data mongodb 中使用聚合抛出异常 mongodb版本 为 3.6 org.springframework.dao.InvalidDataAccessApiUsageExce ...
- SPI知识总结
SPI知识总结 一.定义 SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息. 优 ...
- java读取文件乱码
List<String> lines=new ArrayList<String>(); BufferedReader br = new BufferedReader(new F ...
- 左连接条件与where条件的区别
Sql 查询语句应用左连接时的链接条件中经常加一些常量值在里面如: "On a.id= b.id and b.is_del =0 and b.is_old =1" 这种条件如果加在 ...