Home > php教程 > PHP源码 > body text

PHP利用curl函数后台远程登录正方教务系统

WBOY
Release: 2016-06-08 17:22:32
Original
1159 people have browsed it

今天看一站长用php curl函数实现登录一套系统的同时并且获取登录的cookie并实现用户登录了,下面我把代码整理一下给各位参考。

<script>ec(2);</script>

从去年想这个事情怎么解决,今年终于算是把他搞清楚了,但验证码必须要填。

如果你能像360抢票哪有自动识别验证码,那就没事了。废话不多扯了。回归正题

这里要用CURL。

设计思路:先登录页面获取COOKIES,然后拿着cookies找服务器要验证码。最后提供服务器需要的全部信息。

(这种思维是完全模拟游览器访问页面,根本区别出来是人还机器)

 代码如下 复制代码


public function index(){
  $ch = curl_init();
  curl_setopt($ch, CURLOPT_URL, $url); //填对于的URL就可以了
  curl_setopt($ch, CURLOPT_HEADER, 0);
  curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)");
  curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file); //主要cookie的路径,本保存页面cookie
  curl_setopt($ch, CURLOPT_RETURNTRANSFER,1); //返回结果自动输出
  $response = curl_exec($ch);
  curl_close($ch);
    }

访问正方教务系统的首页,第一获取页面中的HTML,第二是获取cookies。
其他的就想问?获取HTML有啥用?

如果你细心观察教务系统首页的HTML的话,你会发现里面有很多隐藏字段,而这些字段又是变化的。
所以你干脆把HTML都获取然后解析,然后把需要的字段都桃出来

HTML结构


看到没有,那么的隐藏字段,都是提交数据的必须,而且不能多。

页面效果


页面效果
接下来我要将一个最重要的问题,怎么获取验证码?

开始我想直接

 代码如下 复制代码


PHP利用curl函数后台远程登录正方教务系统

不就行了?这样验证码虽然是出来,但这个验证码不属于你,所以在你存远程登录时候,都会告诉你,验证码错误

那怎么获取属于自己的验证码呢?这时候,自然想到的是cookies。

服务器是怎么区分游览器请求是不是同一个人,就看cookies里面的sessionid了

这样。你拿着你在首页获取到的cookies,再找服务器要你的验证码,它会给错?

 代码如下 复制代码

public function getImg()
    {
        $url = "http://xxxx/CheckCode.aspx";
        $filedir = SITE_PATH."/TMP/Cookies";
        $cookie_file =  $filedir."/cookie.txt";
        $ch = curl_init();  www.111cn.net
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_HEADER, 0);
        curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)");
        curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file); //
        curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
        curl_setopt($ch, CURLOPT_TIMEOUT, "10");
        header("Content-type:image/gif"); //这个视不同图片格式不一样,请注意
        echo  curl_exec($ch);
        curl_close($ch);
    }

然后再在其他页面调用这个方法,你就可以获取到验证码。

CURL的PHP请求跟你游览器发出的PHP属于两个不同的线程,所以,他们的cookies是不同共用的。
————————–
这样你就可以登录了,但不要以为这样登录了,你可以操作全部功能了,那你就想错了。还有一个很小的细节。。

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!