我们真的需要看到更多的代码,但这里有一个示例位,它从初始请求中收集会话cookie,然后在后续POST中使用它。它使用匿名代理在任意URL上运行GET请求,希望它可以帮助你(虽然它不使用COOKIEJAR,但我认为它可能仍然有帮助)。
<?php
define('TARGET_URL', 'http://moxune.com');
echo 'Sending initial request' . PHP_EOL;
$aHeaders = get_headers("http://420proxy.info");
foreach($aHeaders as $sHeader) {
if(stripos($sHeader, 'set-cookie') !== false) {
// extract the cookie from the first response
$aCookie = explode(':', $sHeader);
$sCookie = trim(array_pop($aCookie));
$oCookie = http_parse_cookie($sCookie);
echo 'Cookie extracted, trying to POST now' . PHP_EOL;
// OK, now let's try the POST request
$ch = curl_init('http://420proxy.info/includes/process.php?action=update');
curl_setopt($ch, CURLOPT_REFERER, '420.proxy.info');
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_COOKIE, $sCookie);
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLINFO_HEADER_OUT, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect: 100-continue'));
//curl_setopt($ch, CURLOPT_COOKIE, http_build_cookie((array)$oCookie));
curl_setopt($ch, CURLOPT_POSTFIELDS, array(
'u' => TARGET_URL,
'allowCookies' => 'off',
'encodeURL' => 'off',
'stripJS' => 'on'
)
);
$response = curl_exec($ch);
die(var_dump($response));
}
}
'CURLOPT_COOKIEJAR零件确实创建了一个cookie' - 您是否确认创建的文件实际上具有cookie值并且不是空的?你能否从第一个请求的响应头部确认“Set-Cookie”头部存在? – drew010 2012-02-13 23:49:15
检查,cookie被创建并且内容反映头的值。 – Arnoldiusss 2012-02-13 23:52:11
我有点茫然,那么你是否愿意发布更完整的代码,也许你试图访问的网站的URL,所以我可以试试? – drew010 2012-02-14 00:12:09