<?php
/**
* @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'] = 'chi';
$loginParams['username'] = '%BD%97%E7%82';
$loginParams['vcode'] = $code;
// $cookieFile 為加載驗證碼時儲存的cookie檔案名
$cookieFile = SCRIPT_ROOT.'cookie.tmp';
// $targetUrl curl 送出的目标位址
$targetUrl = 'http://www.juhutang.com/';
// 參數重置
$content = curlLogin($targetUrl, $cookieFile, $loginParams);
echo $content;
break;
case 'authcode':
// Content-Type 驗證碼的圖檔類型
header('Content-Type:image/png');
showAuthcode('http://www.xxxx.com/imagecode.aspx');
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>
代碼非原創。
轉載于:https://www.cnblogs.com/php411161555/p/3899765.html