所以我遇到了一个相当不寻常的问题。
我有一个我正在连接的RESTful API,因为它的SignIn方法返回一个响应体。响应中是一个以字符串形式出现的授权令牌。然后,我需要将该授权字符串设置为cookie,以便系统识别用户已登录。
我已经编写了PHP来执行cURL请求,该请求成功取回响应授权代码,但是由于该字符串包含“+”和“/”之类的字符,我需要设置原始cookie而不是常规cookie ,因为http编码将生成一个带有“%2B”和“%2F代替”+“和”/“的cookie。
问题是,我的setrawcookie()返回false,其中setcookie()返回true,即使我传给它相同的参数。
此外,如果我要使用PHP回显的授权字符串并使用复制的auth字符串设置静态字符串,则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);
在这种情况下,setrawcookie()失败但setcookie()工作。
响应正文如下: -
1DEbKeyynVTbXeRJ2i5j2+UgwgmuD17VgQtFbzg2LBLmXMLDUY5t9YV2wdqQOcycZumuzqHH3AJ8e8I3nao0VPBuELAoGa6T27jwgAAizCoSyu0maPnXzfFbYkMnOPRhak9/6fQMqspg...
答案 0 :(得分:1)
尝试将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信息(会话)将存储在文件中。