程序员黑科技之夺宝岛
2015-07-03 17:24
531 查看
额,不知道这样好不好。
不过还是希望CSDN不要删除啊,不管是好的坏的,咱们都要开源分享不是。
主要就是基于Chrome能够在Console中执行js来做的。
以京东夺宝岛为例子我们需要做如下的事情:
在Chorme中打开夺宝岛网页,按F12,然后刷新页面
转到Network标签,看所有的请求,研究出那个请求是拿当前价格的
方式是点击请求,看Response中的返回值:
得到结果:http://paimai.jd.com/json/current/englishquery?paimaiId=10473082&skuId=0&t=650541&start=0&end=9
这个链接能够查看所有的出价记录的json字符串,第一个就是当前的报价了
然后就是设置一个加价值,心理价位, 然后提交
再次获得最高价,如果不是我出的那么就再次加价,循环这个过程
当然还是的通过Chrome来知道提交加价的请求应该是什么
这里直接列出结果:http://paimai.jd.com/services/bid.action?
剩下的就是开始写脚本了。
代码还是比较简单,就不多做解释了。这里说一下有个关键的地方是网页分析的部分。就是从请求中拿到了自己想要的数据。
这样样例的请求是一个json,所以能够直接用了,如果是一个html网页应该怎么办呢?
因为现在的网页一般都用了jquery,所以可以使用jquery脚本来做。他的拾取器还是之棒的。
比如这样:
var val = (‘tr:eq(2)′,html);(‘tr:eq(2)’, html);
(‘td:gt(1)’,val).html() 第二个tr的第一个td. 等等
不过还是希望CSDN不要删除啊,不管是好的坏的,咱们都要开源分享不是。
主要就是基于Chrome能够在Console中执行js来做的。
以京东夺宝岛为例子我们需要做如下的事情:
在Chorme中打开夺宝岛网页,按F12,然后刷新页面
转到Network标签,看所有的请求,研究出那个请求是拿当前价格的
方式是点击请求,看Response中的返回值:
得到结果:http://paimai.jd.com/json/current/englishquery?paimaiId=10473082&skuId=0&t=650541&start=0&end=9
这个链接能够查看所有的出价记录的json字符串,第一个就是当前的报价了
然后就是设置一个加价值,心理价位, 然后提交
再次获得最高价,如果不是我出的那么就再次加价,循环这个过程
当然还是的通过Chrome来知道提交加价的请求应该是什么
这里直接列出结果:http://paimai.jd.com/services/bid.action?
剩下的就是开始写脚本了。
var t,count = 1,price=0,pin = getCookie('pin'),f = function(){ $.ajax({ url:'http://paimai.jd.com/json/current/englishquery?paimaiId='+paimaiId+'&skuId=0&t=964468&start=0&end=9', async:false, success:function(data){ var currentPrice = parseFloat(data.currentPrice); console.info("第",count,"次检测商品当前拍卖价格是",currentPrice); if(data.auctionStatus == 2){ console.error("商品拍卖结束,获得者",data.currentUser); clearTimeout(t);return; } if(data.currentPrice < 1500) { if(pin != data.currentUser && price != currentPrice){ $.ajax({ url:'http://paimai.jd.com/services/bid.action?t=369168&paimaiId='+paimaiId+'&proxyFlag=0&bidSource=0&price='+(currentPrice+1), async:false, success:function(data1){ console.warn("第",count,"次加价拍,本次出价",(currentPrice+1),"出价结果",data1.message); if(data1.result == 200){ currentPrice = currentPrice+1; } else { if(data1.result == 516) {clearTimeout(t);return;} } } }); } else { console.info("商品价格未变,忽略加价"); } price = currentPrice; t = setTimeout(f,1000); } else { console.error("商品价格高于原价5折,停止加价"); clearTimeout(t); } } }); count++; } f(); //暂停 clearTimeout(t)
代码还是比较简单,就不多做解释了。这里说一下有个关键的地方是网页分析的部分。就是从请求中拿到了自己想要的数据。
这样样例的请求是一个json,所以能够直接用了,如果是一个html网页应该怎么办呢?
因为现在的网页一般都用了jquery,所以可以使用jquery脚本来做。他的拾取器还是之棒的。
比如这样:
var val = (‘tr:eq(2)′,html);(‘tr:eq(2)’, html);
(‘td:gt(1)’,val).html() 第二个tr的第一个td. 等等
相关文章推荐
- 我的前端面试题
- 黑马程序员学习笔记 Java的三大框架
- 黑马程序员学习笔记 关于继承
- 黑马程序员学习笔记 IO流详解
- 面试题31:连续子数组的最大和
- 2015爱奇艺暑期实习生面试
- 关于《剑指offer》中面试题30中的第一种算法的推导
- 一个女菜鸟程序员的奋起
- 115个Java面试题和答案
- 黑马程序员学习笔记 Java中多线程与并发的总结
- 黑马程序员学习笔记 Java在win7中环境变量的配置
- 黑马程序员学习日记 Java中的垃圾回收机制
- 黑马程序员—java基础总结2
- 黑马程序员—java基础总结1
- 黑马程序员—Java面向对象程序设计
- 黑马程序员—继承
- 黑马程序员学习日记 overload与override的区别
- 工作面试经历
- 黑马程序员学习日记 Java基础知识精华
- 面试题28:字符串的排列