<?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 提交的目標地址 $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>