首頁 後端開發 php教程 以正方教务系统替例,用php模拟登陆抓取课表、空教室

以正方教务系统替例,用php模拟登陆抓取课表、空教室

Jun 13, 2016 pm 12:19 PM
cookie curl gt post

以正方教务系统为例,用php模拟登陆抓取课表、空教室

  课程格子和超级课程表这两个应用,想必大学生都很熟悉,使用自己的学号和教务系统的密码,就可以将自己的课表导入,随时随地都可以在手机上查看。

  其实稍微了解一点php的话,我们也可以做一个类似这样的web 应用。

  1,解决掉验证码

    其实这是正方的一个小bug,当我们进入登陆界面时,浏览器会去请求服务器,服务器会生成一个验证码图片。如果我们不去请求这个图片,那么正方后台也不会生成相应的        验证码,于是这样我们就有了可乘之机,让我高兴会儿~这时,我们在不填写验证码的情况下,可以很流畅的进入。大家可以在自己的电脑上禁止访问验证码的地址,然后试试这        是不是真的~当然,这只对正方有效。

  2,php 的curl 模拟登陆

    这里直接贴一个脚本之家对 curl 的讲解吧 http://www.jb51.net/article/51299.htm

    接下来就是相关代码了,相信很多人和我一样,只喜欢看例子,对于长篇大论的讲解,转头就走……不过这个习惯还是不好……废话不多说!

    

//模拟登陆	function curl_request($url,$post='',$cookie='', $returnCookie=0){	        $curl = curl_init();	        curl_setopt($curl, CURLOPT_URL, $url);	        curl_setopt($curl, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; Trident/6.0)');	        curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);	        curl_setopt($curl, CURLOPT_AUTOREFERER, 1);	        curl_setopt($curl, CURLOPT_REFERER, "这里一定要换成教务系统登陆的url"); //填写教务系统url	        if($post) {	            curl_setopt($curl, CURLOPT_POST, 1);	            curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($post));	        }	        if($cookie) {	            curl_setopt($curl, CURLOPT_COOKIE, $cookie);	        }	        curl_setopt($curl, CURLOPT_HEADER, $returnCookie);	        curl_setopt($curl, CURLOPT_TIMEOUT, 20);	        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);	        $data = curl_exec($curl);	        if (curl_errno($curl)) {	            return curl_error($curl);	        }	        curl_close($curl);	        if($returnCookie){	            list($header, $body) = explode("\r\n\r\n", $data, 2);	            preg_match_all("/Set\-Cookie:([^;]*);/", $header, $matches);	            $info['cookie']  = substr($matches[1][0], 1);	            $info['content'] = $body;	            return $info;	        }else{	            return $data;	        }    }
登入後複製

  3,教务系统登陆页面的隐藏字段

    举个栗子

    

    <input type="hidden" name="__VIEWSTATE" value="dDwyODE2NTM0OTg7Oz61eIbnKVojBioGYtg2vsy2SklwiA==">
登入後複製

    这些东西在登陆的时候也是需要带上的,顺便贴出函数,顺便暴漏了博主的学校……皇家种地大学(主要是正则表达式的运用)

    

    <br />  //登陆页面的隐藏字段<br />  function getView(){	    $url = 'http://jw.hzau.edu.cn/default2.aspx';	    $result = curl_request($url);	    $pattern = '/<input type="hidden" name="__VIEWSTATE" value="(.*?)" \/>/is';	    preg_match_all($pattern, $result, $matches);	    $res[0] = $matches[1][0];	         	    return $res[0] ;	}
登入後複製

  //返回教室查询页面的隐藏值
  private function getViewJs($cookie,$xh){
    $url = "http://jw.hzau.edu.cn/xxjsjy.aspx?xh={$xh}";
    $result = curl_request($url,'',$cookie);
    $pattern = '//is';
    preg_match_all($pattern, $result, $matches);
    $res[0] = $matches[1][0];
    return $res[0] ;
  }

  4,cookie 的获取

    

function login($xh,$pwd){	    $url = 'http://jw.hzau.edu.cn/default2.aspx';	    $post['__VIEWSTATE'] = $this->getView();	    $post['txtUserName'] = $xh; //填写学号	    $post['TextBox2'] = $pwd;  //填写密码	    $post['txtSecretCode'] = '';	    $post['lbLanguage'] = '';	    $post['hidPdrs'] = '';	    $post['hidsc'] = '';	    $post['RadioButtonList1'] = iconv('utf-8', 'gb2312', '学生');	    $post['Button1'] = iconv('utf-8', 'gb2312', '登录');	    $result = curl_request($url,$post,'', 1);	    return $result['cookie'];	}
登入後複製

  5,让我们来试试查课表的功能,格式有点乱额,大家凑合着看,我把课表转成了一个二维关联数组

    

//返回课表字符串private function classresult($xh,$pwd){    	date_default_timezone_set("PRC"); //时区设置    	$classList = "";//声明课表变量    	$cookie = $this->login($xh,$pwd);    	$view = $this->getViewJs($cookie,$xh);//验证密码是否正确    	//如果密码正确        if (!empty($view)) {        	$url = "http://jw.hzau.edu.cn/xskbcx.aspx?xh={$xh}";	        $result = curl_request($url,'',$cookie);  //保存的cookies			preg_match_all('/<table id="Table1"[\w\W]*?>([\w\W]*?)<\/table>/',$result,$out);	        $table = $out[0][0]; //获取整个课表	        preg_match_all('/<td [\w\W]*?>([\w\W]*?)<\/td>/',$table,$out);	        $td = $out[1];	        $length = count($td);	    	//获得课程列表	    	for ($i=0; $i < $length; $i++) { 	    		$td[$i] = str_replace("<br>", "", $td[$i]);	    		$reg = "/{(.*)}/";	    		    		if (!preg_match_all($reg, $td[$i], $matches)) {	    			unset($td[$i]);	    		}			}			$td = array_values($td); //将课程列表数组重新索引			$tdLength = count($td);			for ($i=0; $i < $tdLength; $i++) { 				$td[$i] = iconv('GB2312','UTF-8',$td[$i]);			}			//将课表转换成数组形式			function converttoTable($table){				$list = array(					'sun' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					),					'mon' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					),					'tues' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					),					'wed' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					),					'thur' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					),					'fri' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					),					'sat' => array(						'1,2' => '',						'3,4' => '',						'5,6' => '',						'7,8' => '',						'9,10' => ''					)				);				$week = array("sun"=>"周日","mon"=>"周一","tues"=>"周二","wed"=>"周三","thur"=>"周四","fri"=>"周五","sat"=>"周六");				$order = array('1,2','3,4','5,6','7,8','9,10');				foreach ($table as $key => $value) {					$class = $value;					foreach ($week as $key => $weekDay) {						$pos = strpos($class,$weekDay);						// echo $pos;						if ($pos) {							$weekArrayDay = $key; //获取list数组中的第一维key 							foreach ($order as $key => $orderClass) {								$pos = strpos($class,$orderClass);								if ($pos) {									$weekArrayOrder = $orderClass; //获取该课程是第几节									break;								}							}							break;						}					}					$list[$weekArrayDay][$weekArrayOrder] = $class;				}				return $list;			}								//调用函数			return converttoTable($td);        }else{        	return 0;        }	}
登入後複製

  6,再试试查询空教室的功能

    

//空教室查询结果	public function roomresult(){		$xh = ""; //设置学号		$pwd = "";  //学号对应的密码		$cookie = $this->login($xh,$pwd);        $url = "http://jw.hzau.edu.cn/xs_main.aspx?xh={$xh}";        $result = curl_request($url,'',$cookie);  //保存的cookies        $url="http://jw.hzau.edu.cn/xxjsjy.aspx?xh={$xh}";        $post['Button2'] = iconv('utf-8', 'gb2312', '空教室查询');        $post['__EVENTARGUMENT']='';        $post['__EVENTTARGET']='';        $post['__VIEWSTATE'] = $this->getViewJs($cookie,$xh);        $post['ddlDsz'] = iconv('utf-8', 'gb2312', '单');        $post['ddlSyXn'] = '2014-2015'; //学年        $post['ddlSyxq'] = '1';         $post['jslb'] = '';        $post['xiaoq'] = '';        $post['kssj']=$_GET['start'];  //提交的开始查询时间          $post['sjd']=$_GET['class'];//提交的课程节次        $post['xn']='2014-2015';//所在学年        $post['xq']='2';//所在学期        $post['xqj']='6';//当天星期几        $post['dpDataGrid1:txtPageSize']=90;//每页显示条数        $result = curl_request($url,$post,$cookie,0);				preg_match_all('/<span[^>]+>[^>]+span>/',$result,$out);        $tip = iconv('gb2312', 'utf-8', $out[0][3]);//获取页面前部的提示内容        preg_match_all('/<table[\w\W]*?>([\w\W]*?)<\/table>/',$result,$out);        $table = iconv('gb2312', 'utf-8', $out[0][0]); //获取查询列表				$this->load->view("classroom",array('tip'=>$tip,'table'=>$table));    }
登入後複製

  总结起来就是这些了,每个学校的教务系统都不尽相同,这时我们可以借助火狐浏览器的 firebug 抓包,看看到底提交了哪些东西。如果不成功,要看看自己该提交的东西post 上去了没有,如果再不成功,额……可以联系我 [email protected]

  就这些了,赶快去试试吧!

1楼——石头——
写得不错~赞一个
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1666
14
CakePHP 教程
1425
52
Laravel 教程
1327
25
PHP教程
1273
29
C# 教程
1253
24
華為GT3 Pro和GT4的差異是什麼? 華為GT3 Pro和GT4的差異是什麼? Dec 29, 2023 pm 02:27 PM

許多用戶在選擇智慧型手錶的時候都會選擇的華為的品牌,其中華為GT3pro和GT4都是非常熱門的選擇,不少用戶都很好奇華為GT3pro和GT4有什麼區別,下面就給大家介紹一下二者。華為GT3pro和GT4有什麼差別一、外觀GT4:46mm和41mm,材質是玻璃鏡板+不鏽鋼機身+高分纖維後殼。 GT3pro:46.6mm和42.9mm,材質是藍寶石玻璃鏡+鈦金屬機身/陶瓷機身+陶瓷後殼二、健康GT4:採用最新的華為Truseen5.5+演算法,結果會更加的精準。 GT3pro:多了ECG心電圖和血管及安

Linux下更新curl版本教程! Linux下更新curl版本教程! Mar 07, 2024 am 08:30 AM

在Linux下更新curl版本,您可以按照以下步驟進行操作:檢查目前curl版本:首先,您需要確定目前系統中安裝的curl版本。開啟終端,並執行以下指令:curl--version該指令將顯示目前curl的版本資訊。確認可用的curl版本:在更新curl之前,您需要確定可用的最新版本。您可以造訪curl的官方網站(curl.haxx.se)或相關的軟體來源,尋找最新版本的curl。下載curl原始碼:使用curl或瀏覽器,下載您選擇的curl版本的原始碼檔案(通常為.tar.gz或.tar.bz2

cookie存在哪裡 cookie存在哪裡 Dec 20, 2023 pm 03:07 PM

Cookie通常儲存在瀏覽器的Cookie資料夾中的,瀏覽器中的Cookie檔案通常以二進位或SQLite格式存儲,如果直接開啟Cookie文件,可能會看到一些亂碼或無法讀取的內容,因此最好使用瀏覽器提供的Cookie管理介面來檢視和管理Cookie。

電腦上的cookie在哪裡 電腦上的cookie在哪裡 Dec 22, 2023 pm 03:46 PM

電腦上的Cookie儲存在瀏覽器的特定位置,具體位置取決於使用的​​瀏覽器和作業系統:1、Google Chrome, 儲存在C:\Users\YourUsername\AppData\Local\Google\Chrome\User Data\Default \Cookies中等等。

PHP Curl中如何處理網頁的 301 重定向? PHP Curl中如何處理網頁的 301 重定向? Mar 08, 2024 am 11:36 AM

PHPCurl中如何處理網頁的301重定向?使用PHPCurl發送網路請求時,常會遇到網頁回傳的301狀態碼,表示頁面被永久重定向。為了正確處理這種情況,我們需要在Curl請求中加入一些特定的選項和處理邏輯。以下將詳細介紹在PHPCurl中如何處理網頁的301重定向,並提供具體的程式碼範例。 301重定向處理原理301重定向是指伺服器回傳了一個30

手機cookie在哪裡 手機cookie在哪裡 Dec 22, 2023 pm 03:40 PM

手機上的Cookie儲存在行動裝置的瀏覽器應用程式中:1、在iOS裝置上,Cookie儲存在Safari瀏覽器的Settings -> Safari -> Advanced -> Website Data中;2、在Android裝置上,Cookie儲存在Chrome瀏覽器的Settings -> Site settings -> Cookies中等等。

Cookie工作原理是什麼 Cookie工作原理是什麼 Sep 20, 2023 pm 05:57 PM

Cookie運作方式涉及到伺服器發送Cookie、瀏覽器儲存Cookie以及瀏覽器對Cookie的處理和儲存。詳細介紹:1、伺服器發送Cookie,伺服器會傳送一個包含Cookie的HTTP回應標頭給瀏覽器。這個Cookie包含了一些訊息,例如使用者的身份認證、偏好設定或購物車內容等,瀏覽器接收到這個Cookie後,會將它儲存在使用者的電腦上;2、瀏覽器儲存Cookie等等。

cookie洩漏有什麼危害 cookie洩漏有什麼危害 Sep 20, 2023 pm 05:53 PM

Cookie洩漏的危害有導致個人識別資訊被竊、個人線上行為被追蹤、帳戶被竊等。詳細介紹:1、個人識別資訊被盜竊,例如姓名、電子郵件地址、電話號碼等,這些資訊可能被不法分子用於進行身份盜竊、欺詐等違法行為;2、個人在線行為被追踪,通過分析cookie中的數據,不法分子可以了解用戶的瀏覽歷史、購物偏好、興趣愛好等;3、帳戶被盜,繞過登入驗證,直接存取用戶的帳號等等。

See all articles