Casperjs是基于Phantomjs的,而Phantom JS是一个服务器端的 JavaScript API 的 WebKit。
这跟我一直想找个自带浏览器内核的后台东西的想法“暗合”。所以,在我发现这东西的时候就已经开始不由自主的兴奋起来了,研究一番之后,果不其然,后台连接网站和页面交互一下子变得异常简单起来。尤其是对需要登录才可进行的网页操作。
于是乎,我就用它来写了两个小例子用来做一些登录网站后点击网上的一些链接和按钮的操作,在编写过程中,给人一种“想点哪里点哪里,咱们再也不用担心Cookie的问题~”的感觉~
看完这个例子,同志们是不是不自觉的想起了某些比如“签到”,”每日登录领取“之类的词呢?
[1].[代码] 登录沪江英语自动打卡 跳至 [1]
01 | var casper = require('casper').create({ |
07 | userAgent: 'Mozilla/5.0 (Windows NT 6.1; rv:17.0) Gecko/20100101 Firefox/17.0' |
11 | casper.options.viewportSize = {width: 1680, height: 924}; |
12 | casper.start('http://bulo.hujiang.com/app/login?source=nbulo&returnurl=/home/'); |
13 | casper.waitForSelector("form#myform input[name='txtUsername']", |
15 | this.test.assertExists("form input[name='txtUsername']"); |
17 | 'txtUsername':'shixiaobao17', |
18 | 'txtPassword':'×××××your password*****' |
20 | this.click("input#btnLogin"); |
23 | this.test.assertExists("form input[name='txtUsername']"); |
26 | casper.waitFor(function check() { |
27 | return this.getCurrentUrl().indexOf("bulo.hujiang.com/home")>-1; |
29 | console.log("登录成功!!!!!!!!!!!!"); |
31 | console.log("执行登录后的其它操作!!!!!!!!!!!!"); |
32 | if(this.exists("#btn_card_do")){ |
33 | this.click("#btn_card_do"); |
34 | this.waitForSelector("#my_hb_btn",function success(){ |
40 | console.log("今天已经打过卡啦!"); |
44 | casper.run(function() {this.test.renderResults(true);}); |