首先說明,不是用php自動識別驗證碼,而是有驗證碼的情況下,讓你通過curl 帶着cookies去請求遠程資源,從而通過合法的身份驗證。主要用來抓取需要登錄后才能訪問的資源。
思路就是獲取到驗證碼之后把驗證碼存儲為一個圖片,然后程序休眠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"; //取出驗證碼 www.111cn.net $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; } //啦啦啦,開始做你想做的事吧。。。。。