想象以下场景:我打开一个 CURL 连接并通过 POST 传递一些 XML-Logindata。服务器以 302 重定向进行响应,其中设置会话 cookie 并将我重定向到以下“欢迎”页面。如果我启用 FOLLOWLOCATION,则重定向页面上设置的 cookie 会丢失,并且欢迎页面会失败并显示“会话已过期”消息。如果我禁用 FOLLOWLOCATION,我不会被重定向(显然),并且会得到一个 HTML 页面,其中包含“该页面已移动到另一个位置”以及一个引导我进入欢迎页面的链接。这在设置 cookie 时有效,但我需要遵循重定向并直接进入欢迎页面。
那么,如何维护 cookie 以便正确设置它们呢?
到目前为止,这是我的代码:
$ch = curl_init('https://www.example.com/login');
curl_setopt($ch, CURLOPT_AUTOREFERER, true);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_POSTFIELDS, '<some xml data>');
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_COOKIEJAR, 'cookie.txt');
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_HTTPHEADER, array("Content-Type: text/xml; charset=UTF-8"));
curl_exec($ch);
curl_close($ch)
谢谢你的帮助!
;