首页 > 代码库 > php 带cookie登陆
php 带cookie登陆
<?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="http://www.mamicode.com/?act=authcode" style=‘width: 100px; height:40px ‘ frameborder=0 ></iframe><form><input type="hidden" name="act" value="http://www.mamicode.com/login"><input type="text" name="code" /><input type="submit" name="submit" ></form>
代码非原创。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。