php curl 携带session,PHP curl session 使用

本文详细介绍了如何通过PHP的cURL库获取HTTP响应头中的Cookie,并在后续请求中设置和利用sessionid,以实现跨站请求。包括设置header、POST数据、正则匹配Cookie,以及使用Cookie jar来持久化会话信息,适用于处理前后端交互的场景。
摘要由CSDN通过智能技术生成

直接获取header中cookie(sessionid)用来继续请求

$url = 'test.com'; //url地址

$post = "id=user&pwd=123456"; //POST数据//或GET

$ch = curl_init($url); //初始化

curl_setopt($ch,CURLOPT_HEADER,1); //将头文件的信息作为数据流输出

curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); //返回获取的输出文本流

curl_setopt($ch,CURLOPT_POSTFIELDS,$post); //发送POST数据

$content = curl_exec($ch); //执行curl并赋值给$content

preg_match('/Set-Cookie:(.*);/iU',$content,$str); //正则匹配

$cookie = $str[1]; //获得COOKIE(SESSIONID)

curl_close($ch); //关闭curl/*-----使用COOKIE-----*/

curl_setopt($ch,CURLOPT_COOKIE,$cookie);//设置cookie再次请求

保存到文件用来请求

$cookie_jar = dirname(__FILE__)."/pic.cookie";

$url = "http://test.com/";

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_HEADER, 0);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_jar);

$content = curl_exec($ch);

curl_close($ch);

//之后的请求

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, 'http://test.com/check.action?');

curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_jar);

curl_setopt($ch, CURLOPT_HEADER, 0);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

curl_setopt($ch, CURLOPT_POSTFIELDS, $post);

$ret = curl_exec($ch);

curl_close($ch);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值