PHP绕过网站登录,绕过验证码,模拟登录 php

这几天一直在做识别验证码的API,已经做出来了,不过我突然有发现可以绕过验证码,

先上代码

header("Content-Type: text/html; charset=utf-8");

function login_get($url, $cookie) {

$curl = curl_init();//初始化curl模块

curl_setopt($curl, CURLOPT_URL, $url);//登录提交的地址

curl_setopt($curl, CURLOPT_HEADER, 0);//是否显示头信息

curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);//是否自动显示返回的信息

curl_setopt($curl, CURLOPT_COOKIEJAR, $cookie); //设置Cookie信息保存在指定的文件中

curl_setopt($curl, CURLOPT_GET, 1);//提交方式

$rs=curl_exec($curl);//执行

curl_close($curl);

return $rs;

}

function get_content($url, $cookie) {

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_HEADER, 0);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); //读取cookie

$rs = curl_exec($ch); //执行cURL抓取页面内容

curl_close($ch);

return $rs;

}

//设置cookie保存路径

$cookie = dirname(__FILE__) . '/cookie.txt';

//登录地址

$id='学号';

$psw='密码';

$pswd=strtoupper(md5($psw));//密码md5加密且转为全大写

$url = "http://202.119.81.112:9080/njlgdx/xk/LoginToXk?method=verify&USERNAME=$id&PASSWORD=$pswd";

//登录

login_get($url, $cookie);

//登录后要获取信息的地址 ,获取登录页的信息

$url2='http://202.119.81.112:9080/njlgdx/xskb/xskb_list.do?Ves632DSdyV=NEW_XSD_PYGL';//课表地址

$content=get_content($url2, $cookie);

//删除cookie文件

@ unlink($cookie);

echo $content;

?>

为什么这样可以呢?介绍一下我的发现过程

0818b9ca8b590ca3270a3433284dd417.png

这是南理工教务处登录界面,打开抓包工具,正常登录

0818b9ca8b590ca3270a3433284dd417.png

登录后的主界面,post 四个参数,最后一个是验证码,我们要绕过验证码

0818b9ca8b590ca3270a3433284dd417.png

点击右上角注销

0818b9ca8b590ca3270a3433284dd417.png

注意地址栏有所变化,右边get的目标地址和刚刚不一样,继续登录

0818b9ca8b590ca3270a3433284dd417.png

发现这次post的地址非常特殊,后半段是 学号+一段数据,显然那是密码的md5加密结果。

0818b9ca8b590ca3270a3433284dd417.png

可以通过get获得页面,选择这个地址

然后就是上面的代码,

结果页面

0818b9ca8b590ca3270a3433284dd417.png

这算是学校系统一个小bug吧,不需要验证码就能进。我需要“上交给国家吗?”  哈哈哈

不管这个以后能不能用,我的验证码处理API也做的差不多了,一样进入。。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值