最后更新时间为 2019年4月19日
先简单梳理一下WORDPRESS后台上传图片的流程是,WORDPRESS使用MEDIA_HANDLE_UPLOAD函数处理整个图片上传的过程,步骤是:
1、使用WP_HANDLE_UPLPAD把图片上传到WORDPRESS上传目录。
2、然后整理好数据提交给WP_INSERT_ATTACHMENT。
3、WP_INSERT_ATTACHMENT函数调用WP_INSERT_POST插入到WORDPRESS的POSTS数据库表。
4、WP_INSERT_POST把图片信息插入到WORDPRESS的POSTS数据库表之前,会使用WP_UNIQUE_POST_SLUG函数设置唯一的POST_SLUG。
WP_UNIQUE_POST_SLUG会到数据库里面检查图片的名字是否已经有了,有了就会重命名图片的名字,比如1.jpg,就会被重命名为1-2.jpg,如果1-2.jpg 名字也有了,就会重命名为1-3.jpg,以此类推,一直到名字唯一为止。这样会造成上百条SQL 请求。
我们不可能让用户坚持不上传1.jpg 这样太常用的图片名字,但是又要为了防止这个大量SQL查询的过程,我们应该在源头就杜绝这个问题,把图片的名字更改了。
添加如下代码
add_filter('wp_handle_upload_prefilter', function($file) {
if(strlen($file['name'])<=7){ $file['name'] = time().'-'.$file['name']; } return $file; });
这段代码就是如果图片的名字(包括.jpg 后缀名)超过7个字符,就在图片名字前面加上一个时间戳,这样再重复检查的概率可以认为是没有了。