最新消息:阿啰哈,本人90后,目前单身,欢迎妹子们来撩!.(。→‿←。) 微信:frank01991

解决WordPress文章ID不连续问题

Website 林志斌 534浏览

   有很多WordPress博客的固定链接中使用了文章ID,但是WordPress由于种种原因导致了文章ID不连续的问题,也经常有博友在论坛中提问要解决这个问题,但是很少能够得到他们满意的答复。今天我就来告诉你如何完美的解决这个问题,说是完美,可能有点过了,WordPress 3.0 之后的版本都会有个自动草稿,每发表一篇文章就会占两个ID号,目前还没有禁用的方法。还请继续往下看如何一定程度上解决文章ID不连续的问题。当然如果你的固定链接中没有使用post ID,那么对你来说文章ID是透明的,无关紧要。即使固定链接中用了post ID,如果你不是特别在意,连不连续也是无关紧要的,本文对你来说也没多大意义了。

一、禁用文章修订版

     所谓的文章修订版就是你每次修改一次文章,它都会自动帮你保存修改之前的文章版本,专业术语叫做版本控制,这样保证了在误修改的情况下可以还原之前的内容,这个在维基文档的维护方面是有很大帮助的,但是作为我们的小博客,似乎没多大用处,而且这个修订版在数据库中是占据一个ID的,这也是导致文章ID不连续的问题之一。要想禁用文章修订版,可以在 wp-config.php文件中添加:

define('WP_POST_REVISIONS', false);

     也可以在当前主题的functions.php添加以下PHP代码:

// 禁用修订版本,2015年3月5日更新
add_filter( 'wp_revisions_to_keep', 'specs_wp_revisions_to_keep', 10, 2 );
function specs_wp_revisions_to_keep( $num, $post ) {
if ( 'post_type' == $post->post_type )
$num = 0;
return $num;
}

二、删除文章修订版

     禁用了文章修订版之后,数据库中还是保存着之前已经创建的文章修订版,这些其实已经没多大用处,而且占着ID,我们可以将它删除。至于怎么删除,可以在 phpmyadmin 中执行以下SQL语句(会影响置顶文章,慎用!并做好备份):

DELETE a,b,c
FROM wp_posts a
LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)
LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)
WHERE a.post_type = 'revision';

三、删除不必要的附件

     相信很多博友在发布文章都会同时上传/插入一些附件,如图像、视频、音乐等,这些附件可以在WordPress管理后台 – 媒体库中看到,不同媒体对应了不同的文章。可是你要注意的是这些媒体也是占据着文章ID的,它们与文章都保存在同一个数据库表wp_posts中。如果你特别追求文章的ID一定要完美无缺地连续,请不要在发布文章的时候上传/插入这些媒体,并请在WordPress管理后台 – 媒体库中,删除之前上传的媒体(注意这个操作不只是删除记录,而且会删除你上传的文件),需要的话请用FTP重新上传这些文件。

四、禁用自动保存

     自动保存的好处是你在编辑文章的时候,每隔一小段时间系统会自动帮你保存编辑的文章,防止网页突然关闭,导致之前写的几千字哗啦一下全没了。缺点是每篇都文章都会有一个自动保存的记录,同样占据一个文章ID,也是文章ID不连续的原因之一,如果你不需要这个功能,可以在当前主题的functions.php中添加以下代码:

// 禁用自动保存,所以编辑长文章前请注意手动保存。
add_action( 'admin_print_scripts', create_function( '$a', "wp_deregister_script('autosave');" ) );

五、重新排列不连续的文章ID

     方法一:可在当前主题的functions.php中加入以下PHP代码,这样如果你只是单纯发文章,不发页面,不添加菜单,不上传媒体的话,基本上此后的文章ID是连续的,而且不改变之前已经发布的文章ID,不影响SEO:

// WordPress 3.8测试有效
function keep_id_continuous(){
global $wpdb;
// 删掉自动草稿和修订版
$wpdb->query("DELETE FROM `$wpdb->posts` WHERE `post_status` = 'auto-draft' OR `post_type` = 'revision'");
// 自增值小于现有最大ID,MySQL会自动设置正确的自增值
$wpdb->query("ALTER TABLE `$wpdb->posts` AUTO_INCREMENT = 1");  
}
add_filter( 'load-post-new.php', 'keep_id_continuous' );
add_filter( 'load-media-new.php', 'keep_id_continuous' );
add_filter( 'load-nav-menus.php', 'keep_id_continuous' );

     如果你使用了置顶文章、菜单和父子页面等功能,下面的方法失效:

     方法二:完成以上几步,基本上可以保证以后发布的文章ID都会是连续的了,但是之前已经发布的文章ID还是一片混乱,得把他们重新排列,以保证是ID是连续的。我写了一个PHP脚本,你可以通过以下网址下载,下载后用文本编辑器打开,根据开头的说明修改数据库信息,然后将该PHP文件上传至你的博客空间,运行一下看到OK就可以了,你可以到phpmyadmin中查看wp_posts表中的id是不是连续的了。还是那句话,开始之前请先备份你的数据库。(如果你使用了post id作为固定链接,那么将可能改变所有文章的网址,会影响搜索引擎收录;如果你用的插件建立了新的数据库表,如投票插件等,也将会出现问题;如果你的博客中创建了父子关系的页面,运行了以下脚本将会失去此关系。请慎用!)

<?php
/**
* WordPress重新排列不连续的文章ID
* 作者	:Ludou 
* Email:[email protected]
* Blog	:http://www.ludou.org/
* 相关文章:http://www.ludou.org/wordpress-post-id-continuous.html
* 最后修改:2010年10月01日
*/
$hostname_blog = "localhost";
$database_blog = "kashuorg";
$username_blog = "root";
$password_blog = "https://kashu.org";
$blog = mysql_pconnect($hostname_blog, $username_blog, $password_blog) or trigger_error(mysql_error(),E_USER_ERROR); 
$no = 1;
function change_id($id)
{
global $no; 
// 修改post id,并修改分类、标签、自定义字段、评论的对应关系
$sql = 'update wp_posts set ID = ' . $no . ' where ID = ' . $id;
mysql_query($sql);
$sql = 'update wp_term_relationships set object_id = ' . $no . ' where object_id = ' . $id;
mysql_query($sql);
$sql = 'update wp_postmeta set post_id = ' . $no . ' where post_id = ' . $id;
mysql_query($sql);
$sql = 'update wp_comments set comment_post_ID = ' . $no . ' where comment_post_ID = ' . $id;
mysql_query($sql);
$no = $no + 1;
}
mysql_select_db($database_blog, $blog);
$query_postRecord = "SELECT ID FROM wp_posts ORDER BY ID ASC";
$all_postRecord = mysql_query($query_postRecord);
$row_postRecord = mysql_fetch_assoc($all_postRecord);
do {
change_id( $row_postRecord['ID'] );	
} while ($row_postRecord = mysql_fetch_assoc($all_postRecord));
// 重新设置post id自增起点
mysql_query('alter table wp_posts AUTO_INCREMENT = ' . $no);
echo 'ok';
?>

via: http://www.ludou.org/wordpress-post-id-continuous.html

WordPress强迫症技巧:让文章(ID)地址完美连续(障眼法)

这几天博客一直被CC攻击,虽然也没带来什么影响,但是因为多IP的并发会导致带宽不够,所以暂时用上了百度云加速。因此,导致之前前台刷新缓存功能也就失效了,因为百度云加速节点还缓存了一份呢!

所以,这些天折腾了下WordPress评论的动态加载机制,而且已成功实现!打算先测试2天,没有问题之后再发文分享,确保读者拿到的是最完善的的代码与教程。

今天有博友在中国博客联盟的群里提到了WordPress文章ID不同步的问题。我作为强迫症,又不喜欢用乱糟糟的文章名称来作为固定链接,所以对于WordPress文章ID不连续也是深恶痛绝已久!WordPress文章ID不连续这个问题,网络上有很多千篇一律的教程,都是要你关闭文章修订版本、关闭自动草稿,完了还来一句:“这样就可以完美解决文章ID不连续问题了。”

实际上,按照这些方法操作一遍之后,你会发现这个问题依然没有解决!虽然ID不连续问题有所缓解,但是只要你上传图片或其他附件,就会占用ID,导致文章ID不连续!所以,这个问题依然没能解决!!!

那到底怎样才能彻底解决?

从上传图片那一步看,我们只要找到上传图片的处理代码,然后将数据库操作代码给屏蔽了,就能彻底根治这个问题!但是,先不说修改这些核心代码如何如何麻烦,一旦WordPress更新,我们又得重新来一遍!所以,不到万不得已,我们最好不要动WordPress核心代码。

那该如何是好?

今天,讨论这个问题的时候,突然灵光一闪,既然直接实现有困难,那我们就换一个思路好了!

思路如下:

①、在后台固定链接设置中,将文章固定链接设置为/%postname%.html的形式;

②、写文章时,将文章别名设置为阿拉伯数字形式,并且和上下文保持连续即可。

那么问题来了,新博客从头开始确实可以每次写文章都用连续的数组作为ID,那我们这种有了不少文章的老博客怎么办?难道真的只有新博客可以用这个方法,老博客只能干瞪眼?其实不然,请继续往下看!

已有不少文章的博客,出于SEO考虑,我们不可能因为文章ID不连续就全部重新来过一次,造成了大量的404。那我们换一个角度:我们还是用%postname%这个思路,然后将已存在的文章的别名直接修改为它对应的ID,以后新写的文章则直接将别名设置为与上一篇连续的数字即可!虽说,老文章存在不连续,但是至少以后发布的新文章是绝对连续的,也算是间接满足了一下强迫症的需求。

下面说具体做法:

这要一篇一篇去修改旧文章别名=ID也太苦逼了!

所以我们可以直接修改数据库来批量设置别名=文章ID:

方法1、进入mysql命令或者phpmyadmin的SQL,执行如下命令即可:

update wp_posts set post_name=ID where post_status='publish' and post_type='post';

Ps:wp_posts是WordPress的文章数据表,wp_是默认的前缀,如果自定义更改过,请根据实际修改即可。 

方法2、如果是虚拟主机,可以使用以下PHP代码:

<?php
/**
* 将所以已发布的文章别名修改成对应ID,让文章以别名完美连续 By 张戈博客
* 文章地址:http://zhangge.net/5008.html
* Ps:备份网站数据库后,请放到WordPress根目录执行,成功后请记得删除!
**/
require('./wp-blog-header.php');
global $wpdb;
$wpdb->query("UPDATE $wpdb->posts SET post_name = ID WHERE post_status = 'publish' AND post_type = 'post'");
echo 'Update Success!';
?>

将以上代码保存为php文件,比如uppostname.php,并上传到网站根目录,执行即可,成功后记得删除!

Ps:所有设置数据库的操作务必记得先备份,避免因失误带来无法挽回的损失。

成功完成以上步骤之后,你之前发布的文章的别名就全部变成了对应的ID了!这时候你就可以放心大胆的将固定链接设置为/%postname%.html了!后续写文章,手动将文章别名设置为与上文连续的数字即可让文章地址完美连续!

目前张戈博客有300多篇文章,ID已用到了5000+,已实施以上方法,后续的文章将从5009完美连续!!

贴张效果截图:

也许有些人会觉得这个方法太麻烦,每次写文章不但需要看一下上一篇文章的别名用到哪个数字了,还要额外手动修改别名。但尼玛是强迫症啊,还喜欢偷懒的话,该干嘛干嘛去啊,千万别纠结这些没用的,小心着急上火哟!

好了,文章介绍的方法非常简单,希望那些要用WordPress做站、并且有强迫症的朋友,能早点看到这篇文章,免得后面抓耳挠腮哟!

via: http://zhangge.net/5008.html

转载请注明:林志斌 » 解决WordPress文章ID不连续问题

发表评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址