我正在使用基于HTTP cookie的身份验证,在身份验证后,我得到了响应中的cookie,
另一个步骤是将请求中的cookie发送给API。以及发布/获取请求
下面的例子是我的卷曲
$cookie_jar= $_COOKIE['DesigntoolAuth'];
//$ch = curl_init($url);
// The data to send to the API
$postData = array(
'ProjectId' => $projectId,
'ProjectName' => $proname,
'ProjectDetails' => $details,
'UserId' => $userId
);
$data_string = json_encode($postData);
// Setup cURL
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_VERBOSE, true);
curl_setopt($c, CURLOPT_COOKIEFILE, $cookie_jar);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
'Content-Type: application/json'
//'Content-Length: ' . strlen($data_string)
));
$api_result = curl_exec($ch);
echo $api_result;
任何人都可以告诉我如何发送cookie?
答案 0 :(得分:0)
CURLOPT_COOKIEFILE
包含cookie数据的文件的名称。 cookie文件可以是Netscape格式,也可以是转储到文件中的普通HTTP样式的标头。如果名称为空字符串,则不会加载cookie,但仍会启用cookie处理。
这意味着CURLOPT_COOKIEFILE
需要引用包含您需要发送的cookie的文件。该文件是存在于运行cURL的服务器上的文件,后者又将cookie数据传输到远程主机。我希望文件上需要读访问权限。
可以找到描述Netscape格式外观的好答案here
此外,如果您想保留请求期间生成的Cookie,还需要设置CURLOPT_COOKIEJAR
。