首先,感谢你为我的这篇文章点了推荐,虽然你可能没有点,但是我已经“好心”的帮你点了。不信?那你先看下文章右下角的推荐数,然后刷新下页面看看。
下面我来说下实现原理,其实没什么技术含量,懂点js的人都能进行操作。
我先用firebug查看了页面上推荐按钮的DOM,发现其实是个点击事件:
是一个叫 DiggIt() 的方法,分别传入了3个参数,看参数命名应该分别是文章ID、博客ID和一个写死的1。这下就简单了,是不是我直接在页面底部写句一模一样的方法,就能实现了呢?
于是我到后台“设置”里面找到页尾输入筐,调用这个方法,如下:
欣喜的去测试,发现测试失败,在我更新后台设置后,再去看,发现整个方法都别过滤掉了,无奈,只能进行第二套计划,就是找到这个方法,最终我在common.js里找到这个方法,如下:
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方法,保证它在页面全部加载完后再执行。于是,最终的代码就是:
$().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:补充一句,我已经给官网邮箱和小组里都发帖告知官网这个问题,希望博客园能尽快处理。