curl模拟post请求提交

header('content-type:text/html;charset=utf-8');
function curlPost($url,$data,$method){
	$ch = curl_init();	 //1.初始化
	curl_setopt($ch, CURLOPT_URL, $url); //2.请求地址
	curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);//3.请求方式
	//4.参数如下
	curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);//https
	curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
	curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');//模拟浏览器
	curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
	curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
        curl_setopt($ch, CURLOPT_HTTPHEADER,array('Accept-Encoding: gzip, deflate'));//gzip解压内容
        curl_setopt($ch, CURLOPT_ENCODING, 'gzip,deflate');
    
	if($method=="POST"){//5.post方式的时候添加数据
		curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
	}
	curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
	$tmpInfo = curl_exec($ch);//6.执行

	if (curl_errno($ch)) {//7.如果出错
		return curl_error($ch);
	}
	curl_close($ch);//8.关闭
	return $tmpInfo;
}
$data=array('name' => '1234');
$url="http://www.sohu.com/";

$method="GET";
$file=curlPost($url,$data,$method);
$file=mb_convert_encoding($file,'UTF-8','GBK');
echo $file;


当cookie认证登陆的时候

<?php
	$cookie_file = tempnam('./temp','cookie');
	function weixinPost($url,$data,$method,$setcooke=false,$cookie_file=false){
		$ch = curl_init();	 //1.初始化
		curl_setopt($ch, CURLOPT_URL, $url); //2.请求地址
		curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);//3.请求方式
		//4.参数如下	
		curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
		curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
		curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
		curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
		curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
		
		if($method=="POST"){//5.post方式的时候添加数据	
			curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
		}
		if($setcooke==true){
			curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);
		}else{
			curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);
		}
		curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
		$tmpInfo = curl_exec($ch);//6.执行

		if (curl_errno($ch)) {//7.如果出错
			return curl_error($ch);
		}
		curl_close($ch);//8.关闭
		return $tmpInfo;
	}
	$data=array('username' => '***','password'=>'***');
	$url="http://www.xinxinj.com/login.php";
	$method="POST";
	$file=weixinPost($url,$data,$method,true,$cookie_file);
	echo $file;
		
	$url="http://www.xinxinj.com/admin.php";
	$method="GET";
	$file=weixinPost($url,$data,$method,false,$cookie_file);
	echo $file;
		
?>


如果上述还是无法解决,那么采用以下方案

$ch = curl_init();  
$url = '*******';  
$header = array(
'cookie:********'
);
// 添加apikey到header  
curl_setopt($ch, CURLOPT_HTTPHEADER  , $header);  
//curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);  
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:50.0) Gecko/20100101 Firefox/50.0');  
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);  
curl_setopt($ch, CURLOPT_AUTOREFERER, 1); 
// 执行HTTP请求  
curl_setopt($ch , CURLOPT_URL , $url);  
$res = curl_exec($ch);  
var_dump($res);  

上面的$header中的数组中cookie的内容是现在浏览器登录,然后打开控制台,把cookie的信息粘贴进来


  • 13
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值