【发布时间】:2023-04-06 19:25:01
【问题描述】:
所以我遇到了一个相当不寻常的问题。
我有一个要连接的 RESTful API,它的 SignIn 方法会返回一个响应正文。在响应中是一个以字符串形式出现的授权令牌。然后我需要将该授权字符串设置为 cookie,以便系统识别用户已登录。
我已经编写了 PHP 来执行 cURL 请求,它成功地取回了响应授权代码,但是由于该字符串包含像“+”和“/”这样的字符,我需要设置一个原始 cookie 而不是常规的, 因为 http 编码会生成一个 cookie 用 "%2B" 和 "%2F" 代替 "+" 和 "/"。
问题是,我的 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);
在这种情况下,setrawcookie() 失败但 setcookie() 有效。
响应正文如下所示:-
1DEbKeyynVTbXeRJ2i5j2+UgwgmuD17VgQtFbzg2LBLmXMLDUY5t9YV2wdqQOcycZumuzqHH3AJ8e8I3nao0VPBuELAoGa6T27jwgAAizCoSyu0maPnXzfFbYkMnOPRhak9/6fQMqspg...
【问题讨论】:
-
是的,但是如果你在那里发送一个原始的
+,并且接收方解码那个字符串,那么+会变成一个空格并破坏你的字符串。就 setcookie 而言,它不在乎那个字符串来自哪里。一个字符串就是一个字符串。 setcookie 不知道它来自 curl。