【发布时间】:2015-05-15 07:26:02
【问题描述】:
我有一个脚本,它使用大量 cURL 登录站点并提交一系列表单,但是由于 cURL 请求返回 302 并重定向到块/端点页面,这最近停止工作。如果我在浏览器上执行相同的操作,则没有重定向,只有 200 OK。
我的 cURL 正在使用登录过程返回的 cookie,所以我不认为会话正在被丢弃。
我最初认为缺少 CSRF 令牌(某种形式),给定重定向位置,并且该过程中的后续表单(使用浏览器)包含隐藏的 CSRF 令牌字段,但 URL 不需要发布数据。
cURL 和响应如下:
curl_setopt($ch, CURLOPT_URL, 'https://*******.********.co.uk/Dispatcher?menuid=pos_home');
curl_setopt ($ch, CURLOPT_COOKIEJAR, 'cookie.txt');
curl_setopt($ch, CURLOPT_HEADER, 0);
$content = curl_exec ($ch);
echo "CURL INFO : <BR/><pre>" ;
print_r(curl_getinfo($ch));
返回:
Array
(
[url] => https://*******.********.co.uk/Dispatcher?menuid=pos_home
[content_type] => text/html
[http_code] => 302
[header_size] => 253
[request_size] => 332
[filetime] => -1
[ssl_verify_result] => 20
[redirect_count] => 0
[total_time] => 0.142718
[namelookup_time] => 2.4E-5
[connect_time] => 2.4E-5
[pretransfer_time] => 9.0E-5
[size_upload] => 43
[size_download] => 327
[speed_download] => 2291
[speed_upload] => 301
[download_content_length] => -1
[upload_content_length] => 43
[starttransfer_time] => 0.142659
[redirect_time] => 0
[certinfo] => Array
(
)
[primary_ip] => nnn.nnn.nnn.nn
[primary_port] => 443
[local_ip] => nnn.nnn.nnn.nn
[local_port] => 53154
[redirect_url] => https://*******.********.co.uk/Dispatcher?menuid=badorMissingCSRFT
)
如果有人知道为什么或如何服务器可以对浏览器请求的 cURL 给出不同的响应,我将非常感激 -thanks.of
【问题讨论】:
-
联系网站并询问他们需要什么才能使您的脚本正常工作。
-
“如果有人知道为什么或如何服务器可以对浏览器请求的 cURL 给出不同的响应” – 任何可能的原因,从一些琐碎的事情开始作为用户代理,更详细地说明将您的请求分类为不是来自“浏览器”的原因。如果该网站似乎对您尝试做的事情采取了措施,那么这可能表明他们不希望您这样做......
标签: php curl http-status-code-302