以前我們寫過很多利用curl模擬登錄的,今天我來介紹兩個例子都可以實現對方網站有驗證碼圖片時由用戶輸入驗證碼之后再驗證.
例子,讀取遠程的驗證碼利用框架加載到此頁面然后手工輸入,代碼如下:
- <?php
- /**
- * @author 追逐__something
- * @version $id
- */
- define('SCRIPT_ROOT',dirname(__FILE__).'/');
- $act = trim($_REQUEST['act']);
- switch($act)
- {
- case 'login':
- // 獲取驗證碼
- $code = trim($_REQUEST['code']);
- // $loginParams為curl模擬登錄時post的參數
- $loginParams['act'] = 'login';
- $loginParams['password'] = '111111';
- $loginParams['username'] = 'wlpadmin';
- $loginParams['vcode'] = $code;
- // $cookieFile 為加載驗證碼時保存的cookie文件名
- $cookieFile = SCRIPT_ROOT.'cookie.tmp';
- // $targetUrl curl 提交的目標地址 m.survivalescaperooms.com
- $targetUrl = 'http://local.xx.com/admin/login.php';
- // 參數重置
- $content = curlLogin($targetUrl, $cookieFile, $loginParams);
- echo $content;
- break;
- case 'authcode':
- // Content-Type 驗證碼的圖片類型
- header('Content-Type:image/png');
- showAuthcode('http://local.xx.com/admin/vcode.php?r=0.03192671708666017');
- exit;
- break;
- }
- /**
- * 模擬登錄
- * @param string $url 提交到的地址
- * @param string $cookieFile 保存cookie的文件
- * @param string $loginParams 提交時要post的參數
- * @return string $content 返回的內容
- */
- function curlLogin($url, $cookieFile, $loginParams)
- {
- $ch = curl_init($url);
- curl_setopt($ch,CURLOPT_COOKIEFILE, $cookieFile); //同時發送Cookie
- curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($ch,CURLOPT_POST, 1);
- curl_setopt($ch,CURLOPT_POSTFIELDS, $loginParams); //提交查詢信息
- $content = curl_exec($ch);
- curl_close($ch);
- return $content;
- }
- /**
- * 加載目標網站圖片驗證碼
- * @param string $authcode_url 目標網站驗證碼地址
- */
- function showAuthcode( $authcode_url )
- {
- $cookieFile = SCRIPT_ROOT.'cookie.tmp';
- $ch = curl_init($authcode_url);
- curl_setopt($ch,CURLOPT_COOKIEJAR, $cookieFile); // 把返回來的cookie信息保存在文件中
- curl_exec($ch);
- curl_close($ch);
- }
- ?>
- <iframe src="?act=authcode" style='width: 100px; height:40px ' frameborder=0 ></iframe>
- <form>
- <input type="hidden" name="act" value="login">
- <input type="text" name="code" />
- <input type="submit" name="submit" >
- </form>
例子:思路就是獲取到驗證碼之后把驗證碼存儲為一個圖片,然后程序休眠20秒,在20秒之后由用戶手動查看圖片,并把驗證碼填寫到code.txt文件中,20秒休眠完成后,程序會讀code.txt的驗證碼,這樣再帶著驗證碼進行登錄操作,代碼如下:
- //初始化變量
- $cookie_file = "tmp.cookie";
- $login_url = "http://xxx.com/logon.php";
- $verify_code_url = "http://xxx.com/verifyCode.php";
- echo "正在獲取COOKIE...n";
- $curlj = curl_init();
- $timeout = 5;
- curl_setopt($curl, CURLOPT_URL, $login_url);
- curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
- curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, $timeout);
- curl_setopt($curl,CURLOPT_COOKIEJAR,$cookie_file); //獲取COOKIE并存儲
- $contents = curl_exec($curl);
- curl_close($curl);
- echo "COOKIE獲取完成,正在取驗證碼...n";
- //取出驗證碼 m.survivalescaperooms.com
- $curl = curl_init();
- curl_setopt($curl, CURLOPT_URL, $verify_code_url);
- curl_setopt($curl, CURLOPT_COOKIEFILE, $cookie_file);
- curl_setopt($curl, CURLOPT_HEADER, 0);
- curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
- $img = curl_exec($curl);
- curl_close($curl);
- $fp = fopen("verifyCode.jpg","w");
- fwrite($fp,$img);
- fclose($fp);
- echo "驗證碼取出完成,正在休眠,20秒內請把驗證碼填入code.txt并保存n";
- //停止運行20秒
- sleep(20);
- echo "休眠完成,開始取驗證碼...n";
- $code = file_get_contents("code.txt");
- echo "驗證碼成功取出:$coden";
- echo "正在準備模擬登錄...n";
- $post = "username=maben&pwd=hahahaha&verifycode=$code";
- $curl = curl_init();
- curl_setopt($curl, CURLOPT_URL, $url);
- curl_setopt($curl, CURLOPT_HEADER, false);
- curl_setopt($curl, CURLOPT_RETURNTRANSFER,1);
- curl_setopt($curl, CURLOPT_POSTFIELDS, $post);
- curl_setopt($curl, CURLOPT_COOKIEFILE, $cookie_file);
- $result=curl_exec($curl);
- curl_close($curl);
- //這一塊根據自己抓包獲取到的網站上的數據來做判斷
- if(substr_count($result,"登錄成功")){
- echo "登錄成功n";
- }else{
- echo "登錄失敗n";
- exit;
- }
新聞熱點
疑難解答