绕过验证码,模拟登录 南理教务处

暑假的时候做的识别验证码的API,做出来了,不过后来有发现可以绕过验证码,

只上代码

发现过程详见 原博客地址:http://blog.csdn.net/away_d/article/details/47613829

博客已转移至现网易博客。

[php]  view plain copy
  1. <?php  
  2. header("Content-Type: text/html; charset=utf-8");  
  3. function login_get($url$cookie) {   
  4.     $curl = curl_init();//初始化curl模块   
  5.     curl_setopt($curl, CURLOPT_URL, $url);//登录提交的地址   
  6.     curl_setopt($curl, CURLOPT_HEADER, 0);//是否显示头信息   
  7.     curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);//是否自动显示返回的信息   
  8.     curl_setopt($curl, CURLOPT_COOKIEJAR, $cookie); //设置Cookie信息保存在指定的文件中   
  9.     curl_setopt($curl, CURLOPT_GET, 1);//提交方式  
  10.     $rs=curl_exec($curl);//执行  
  11.     curl_close($curl);  
  12. <span style="white-space:pre">    </span>return $rs;  
  13. }   
  14.   
  15.   
  16. function get_content($url$cookie) {   
  17.     $ch = curl_init();   
  18.     curl_setopt($ch, CURLOPT_URL, $url);   
  19.     curl_setopt($ch, CURLOPT_HEADER, 0);   
  20.     curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);   
  21.     curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); //读取cookie   
  22.     $rs = curl_exec($ch); //执行cURL抓取页面内容   
  23.     curl_close($ch);   
  24.     return $rs;   
  25. }   
  26.   
  27.   
  28.   
  29.   
  30. //设置cookie保存路径  
  31. $cookie = dirname(__FILE__) . '/cookie.txt';   
  32.   
  33.   
  34. //登录地址   
  35. $id='学号';  
  36. $psw='密码';  
  37. $pswd=strtoupper(md5($psw));//密码md5加密且转为全大写  
  38. $url = "http://202.119.81.112:9080/njlgdx/xk/LoginToXk?method=verify&USERNAME=$id&PASSWORD=$pswd";   
  39. //登录   
  40. login_get($url$cookie);   
  41. //登录后要获取信息的地址 ,获取登录页的信息   
  42. $url2='http://202.119.81.112:9080/njlgdx/xskb/xskb_list.do?Ves632DSdyV=NEW_XSD_PYGL';//课表地址  
  43. $content=get_content($url2$cookie);   
  44. //删除cookie文件   
  45. @ unlink($cookie);    
  46.   
  47.   
  48. echo $content;   
  49. ?>  
改进版curl

function _http($url,$data='',$cookiefile='',$cookiejar=''){
$ch=curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
if($cookiefile){
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookiefile);
}
curl_setopt($ch, CURLOPT_REFERER, $url);
if($data){
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data));
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect'));
}
if($cookiejar){
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookiejar);
}
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 500);
$str=curl_exec($ch);
curl_close($ch);
return $str;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值