所以我遇到了一个相当不寻常的问题。
我有一个RESTful API我连接到,它的SignIn方法返回一个响应体。响应中有一个字符串形式的授权令牌。然后,我需要将该授权字符串设置为cookie,以便系统识别用户已登录。
我已经编写了PHP来做cURL请求,它成功地取回响应授权代码,但是由于该字符串包含像"+"answers"/"这样的字符,我需要设置一个原始cookie而不是一个常规的,因为http编码将生成一个"%2B"answers"%2F"代替"+"answers"/"的cookie。
问题是,我的setrawcookie()返回false,而setcookie()返回true,即使我传递给它相同的参数。
此外,如果我要使用PHP回显的授权字符串并将复制的授权字符串设置为静态字符串,则setrawcookie成功。
由于某些原因,PHP不允许我用cURL请求的字符串数据创建原始cookie。有人知道为什么会这样吗?
$data = array("Username" => $_POST['Username'], "Password" => $_POST['Password']);
$data_string = json_encode($data);
$ch = curl_init('https://cloudhub.quivers.com/api/v1/SignIn/Signin');
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_CERTINFO, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
'Content-Type: application/json',
'Content-Length: ' . strlen($data_string))
);
$result = curl_exec($ch);
echo curl_error($ch);
setrawcookie("AuthToken", $result, 0, "/", "www.quivers.com", 1);
在这个例子中,setcookie()失败了,但是setcookie()成功了。
响应正文如下:-
1DEbKeyynVTbXeRJ2i5j2+UgwgmuD17VgQtFbzg2LBLmXMLDUY5t9YV2wdqQOcycZumuzqHH3AJ8e8I3nao0VPBuELAoGa6T27jwgAAizCoSyu0maPnXzfFbYkMnOPRhak9/6fQMqspg...
尝试将curl cookie保存到一个文件中。可以这样做:
curl_setopt( $curl_handle, CURLOPT_COOKIESESSION, true );
curl_setopt( $curl_handle, CURLOPT_COOKIEJAR, "cookie.txt");
curl_setopt( $curl_handle, CURLOPT_COOKIEFILE, "cookie.txt");
现在cookie信息(会话)将被存储在文件中