wordpress wp_insert_post 插入数据 不过滤 ed2k magnet 等特殊字符

最近写了wordpress 采集的脚本,但是插入时ed2k magnet等字符被自动过滤了,其实这是wordpress的自动保护体制。具体代码在wp-includes目录内找到post.php,搜索以下内容:

$postarr = sanitize_post($postarr, 'db'); //这行注释掉,就可以了。

但是这样做整体后台就会失去保护了,下面我们提供另外一种方法,在脚本执行插入时添加代码如下:

kses_remove_filters(); //停止过滤字符
$post_ID = wp_insert_post( $my_post);//wordpress自带的插入功能
kses_init_filters();//重新开启过滤字符

注意:此处只要是安全性能的过滤,比如PHP的’单引号等字符。

这样就不会影响整体影响使用啦~

厂家CPU内存硬盘流量价格购买链接
RamNode11GB25GB-SSD500GB/mUSD $5购买
Linode11GB25GB-SSD1000GB/mUSD $5购买
DigitalOcean11GB25GB-SSD1000GB/mUSD $5/m购买
腾讯云Qcloud22GB50GB-SSD购买
Vultr11GB25GB-SSD1000GB/mUSD $5/m购买

Posted

in

by

Comments

《“wordpress wp_insert_post 插入数据 不过滤 ed2k magnet 等特殊字符”》 有 3 条评论

  1. 泥人传说

    这三段代码要放到哪里,我放到你说的那个文件当中时,貌似文章页保存的时候都会直接出错造成打不开。

    我放到当前的主题函数当中时,貌似这样的写法也是有问题的,保存不了!

    1. 你想达到什么样的效果?请消息描述应用场景、

      1. 泥人传说

        就是让各种各样的种子链接的头部不会被WP给屏蔽掉……

        你这第一种方法不敢乱用。
        第二种方法貌似有问题~~~

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注