前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WordPress强迫症技巧:让文章(ID)地址完美连续(障眼法)

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

作者头像
张戈
发布2018-03-23 14:31:41
9090
发布2018-03-23 14:31:41
举报
文章被收录于专栏:张戈的专栏张戈的专栏

这几天博客一直被 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,执行如下命令即可:

代码语言:javascript
复制
update wp_posts set post_name=ID where post_status='publish' and post_type='post';

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

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

代码语言:javascript
复制
<?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强迫症技巧:让文章(ID)地址完美连续(障眼法)
WordPress强迫症技巧:让文章(ID)地址完美连续(障眼法)

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

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015年01月19日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 那到底怎样才能彻底解决?
  • 那该如何是好?
  • 思路如下:
  • 下面说具体做法:
相关产品与服务
轻量应用服务器
轻量应用服务器(TencentCloud Lighthouse)是新一代开箱即用、面向轻量应用场景的云服务器产品,助力中小企业和开发者便捷高效的在云端构建网站、Web应用、小程序/小游戏、游戏服、电商应用、云盘/图床和开发测试环境,相比普通云服务器更加简单易用且更贴近应用,以套餐形式整体售卖云资源并提供高带宽流量包,将热门开源软件打包实现一键构建应用,提供极简上云体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档