首先,感谢你为我的这篇文章点了推荐,虽然你可能没有点,但是我已经“好心”的帮你点了。不信?那你先看下文章右下角的推荐数,然后刷新下页面看看。
下面我来说下实现原理,其实没什么技术含量,懂点js的人都能进行操作。
我先用firebug查看了页面上推荐按钮的DOM,发现其实是个点击事件:
是一个叫 DiggIt() 的方法,分别传入了3个参数,看参数命名应该分别是文章ID、博客ID和一个写死的1。这下就简单了,是不是我直接在页面底部写句一模一样的方法,就能实现了呢?
于是我到后台“设置”里面找到页尾输入筐,调用这个方法,如下:
欣喜的去测试,发现测试失败,在我更新后台设置后,再去看,发现整个方法都别过滤掉了,无奈,只能进行第二套计划,就是找到这个方法,最终我在common.js里找到这个方法,如下:
代码语言:javascript复制function DiggIt(entryId, blogId, diggType) {
currentDiggEntryId = entryId;
var diggedType = currentDiggType;
if (diggedType == 0) {
ShowDiggMsg('提交中...');
currentDiggType = diggType;
AjaxPost("/ws/digg.asmx/digg", '{entryId:' entryId ',blogId:' blogId ',diggType:' diggType '}', OnDiggSuccess);
}
else if (diggedType == 1) {
ShowDiggMsg('您已经推荐过了!');
}
else if (diggedType == 2) {
ShowDiggMsg('您已经反对过了!');
}
}
当然,我不需要这么多,我只需要这句代码就行:AjaxPost("/ws/digg.asmx/digg", '{entryId:' entryId ',blogId:' blogId ',diggType:' diggType '}', OnDiggSuccess);
于是我把里面的一些参数手动替换掉,最终变成了:AjaxPost("/ws/digg.asmx/digg", '{entryId:' cb_entryId ',blogId:' cb_blogId ',diggType:1}', OnDiggSuccess);
然后我再把它复制到页脚HTML代码处,更新后发现还是过滤掉了。
我开始观察这句代码,通常过滤代码都是按字符串来过滤,只要页面上出现什么字符串,就自动过滤掉。我想,如果把字符串拆开来用“ ”拼接,是否还能过滤掉呢,于是,代码又变成了:AjaxPost("/ws/di" "gg.as" "mx/di" "gg", '{ent' 'ryId:' cb_entryId ',blog' 'Id:' cb_blogId ',digg' 'Ty' 'pe:1}', OnDiggSuccess);
更新,发现没事,妥妥的更新成功了,赶紧去之前的博文里试了一把,成功!
最后,为了保证稳定,我在外面包了一层jquery的ready方法,保证它在页面全部加载完后再执行。于是,最终的代码就是:
代码语言:javascript复制$().ready(function(){
AjaxPost("/ws/di" "gg.as" "mx/di" "gg", '{ent' 'ryId:' cb_entryId ',blog' 'Id:' cb_blogId ',digg' 'Ty' 'pe:1}', OnDiggSuccess);
});
好了,文章到这里就结束了。我只是作为学习研究用,请勿使用于商业用途,否则后果自负。
PS:稍微有一点小bug,就是提交后不能马上更新,需要刷新下页面才能看到。
PS2:通过这个思路,其实还能实现强制留言功能,不过我还是比较看重访客的留言,因为自己做的一些插件需要使用者的反馈。所以我就说个思路,至于实现就让你们自己去操作吧。
PS3:用同样原理也实现了强制关注的功能,实现代码就不公布了,没太大意义。
PS4:补充一句,我已经给官网邮箱和小组里都发帖告知官网这个问题,希望博客园能尽快处理。