ajax报错get,使用七牛CDN导致ajax评论报错{"error":"get from image source failed: E405"} | 落格博客...

最近更新:26th 4月, 2015

发现

因为之前路由一直想要尝试使用第三方的社会化评论框来取代WP自身的评论,但是奈何无论如何也找不到合适的选择,现在只好再次换回了自带的评论框。(好吧反正也没人会来评论。)

但是换回自带的评论框后发现了一个问题,那就是当开启了Ajax之后无论发布什么内容的评论,都会导致{“error”:”get from image source failed: E405″}报错从而无法发布评论。

原因

经google后得到结论,根据这里的记录表明是七牛CDN的问题。当然,事实证明确实是CDN的问题,但可能并不只有七牛才会导致这样的吧,或者我们可以猜想,是CDN导致了这个问题。

原理就是CDN把你的comments-ajax.js文件给缓存走了,结果导致路径错误,这时候我们有两种选择来修复这个问题。

修改js文件让它能够支持你的CDN路径

将这个文件单独排除在CDN的镜像列表之外

解决办法

1、修改comments-ajax.js文件

这种方法的好处是你依旧可以体验完整的CDN镜像服务,你需要打开你主题目录下对应的文件然后修改它,找到如下的代码段(一般应该是在开头的)

1

2

3

4

5

vari=0,got=-1,len=document.getElementsByTagName('script').length;

while(i<=len&& got == -1){

var js_url = document.getElementsByTagName('script')[i].src,

got = js_url.indexOf('comments-ajax.js');i++;

}

然后就在代码后边加入这样一句话

1

js_url=js_url.replace('logcg.qiniudn.com','www.logcg.com');

这样,修改完成后应该是下边的样子

1

2

3

4

5

6

vari=0,got=-1,len=document.getElementsByTagName('script').length;

while(i<=len&& got == -1){

var js_url = document.getElementsByTagName('script')[i].src,

got = js_url.indexOf('comments-ajax.js');i++;

}

js_url=js_url.replace('logcg.qiniudn.com','www.logcg.com');

然后就保存上传就好了,当然,我希望你能搞定七牛的文件更新XD。

2、添加CDN镜像例外

如果你和我一样是使用WP Super Cache来开启CDN镜像的,那你也可以选择我这种修复办法——直接将这个js文件排除在镜像列表之外就好了,虽然加载的时候多了一个js文件,但省去了对付七牛那个缓慢的刷新过程,其实还是很不错的,立竿见影啊~

另外,我想其他的CDN插件应该也会有类似的排除功能,你可以领会精神然后自己去插件里找找——至于直接使用代码实现CDN的大神……请出门左转╮(╯▽╰)╭

好了,找到你WP Super Cache的CDN页面,然后在下边找到“如果是之前有则排除”这一项,将comment-ajax填写进去就好了。

[warning]

记得多个语句之间用英文的逗号来分隔哦!

[/warning]

填写完成的样子如图所示:

476334f16b3d68f434f83f2b161b38b2.png

这样,就只有这一个文件被排除在CDN之外了。

同时,你可以在页面当中检查元素来验证,比如说这样:

8adb5e533f7cb2d1ec8459c57917e092.png

这个时候你去测试评论,就发现已经可以正常使用啦。

路由当时可是同时提交了七牛缓存更新的,截止到这篇文章写完,七牛那边的文件依旧更新不能╮(╯▽╰)╭

总之,还是这样的办法有效瓦~下次如果更换了CDN,也不用再去手动修改js地址了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值