在网上查了一些别人写的模拟登录程序,好多都是通过服务程序apache什么的运行,获取到验证码之后显示在网页上,然后填上再POST出去,这样虽然看起来很友好,但是既然模拟登录,登录后所干的事情就不一定是短时间完成的,所以这就要受到php最大执行时间的限制,而且有些操作还有可能权限不足。我写了一个,思路就是获取到验证码之后把验证码存储为一个图片,然后程序休眠20秒,在20秒之后由用户手动查看图片,并把验证码填写到code.txt文件中,20秒休眠完成后,程序会读code.txt的验证码,这样再带着验证码进行登录操作。代码如下:
view
source
print?
08 | $cookie_file = "tmp.cookie" ; |
09 | $login_url = "http://xxx.com/logon.php" ; |
10 | $verify_code_url = "http://xxx.com/verifyCode.php" ; |
15 | curl_setopt( $curl , CURLOPT_URL, $login_url ); |
16 | curl_setopt( $curl ,
CURLOPT_RETURNTRANSFER,1); |
17 | curl_setopt( $curl , CURLOPT_CONNECTTIMEOUT, $timeout ); |
18 | curl_setopt( $curl ,CURLOPT_COOKIEJAR, $cookie_file ); //获取COOKIE并存储 |
19 | $contents =
curl_exec( $curl ); |
22 | echo "COOKIE获取完成,正在取验证码...\n" ; |
25 | curl_setopt( $curl , CURLOPT_URL, $verify_code_url ); |
26 | curl_setopt( $curl , CURLOPT_COOKIEFILE, $cookie_file ); |
27 | curl_setopt( $curl , CURLOPT_HEADER,0); |
28 | curl_setopt( $curl ,
CURLOPT_RETURNTRANSFER,1); |
29 | $img =
curl_exec( $curl ); |
32 | $fp = fopen ( "verifyCode.jpg" , "w" ); |
35 | echo "验证码取出完成,正在休眠,20秒内请把验证码填入code.txt并保存\n" ; |
39 | echo "休眠完成,开始取验证码...\n" ; |
40 | $code = file_get_contents ( "code.txt" ); |
44 | $post = "username=maben&pwd=hahahaha&verifycode=$code" ; |
46 | curl_setopt( $curl , CURLOPT_URL, $url ); |
47 | curl_setopt( $curl , CURLOPT_HEADER,false); |
48 | curl_setopt( $curl ,
CURLOPT_RETURNTRANSFER,1); |
49 | curl_setopt( $curl , CURLOPT_POSTFIELDS, $post ); |
50 | curl_setopt( $curl , CURLOPT_COOKIEFILE, $cookie_file ); |
51 | $result =curl_exec( $curl ); |
54 | //这一块根据自己抓包获取到的网站上的数据来做判断 |
55 | if (substr_count( $result , "登录成功" )){ |
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理