通过curl登录并重新使用cookie获取第二个请求

时间:2014-01-23 17:17:36

标签: php cookies curl

我正在尝试通过curl登录,并在登录后使用生成的cookie发出第二个请求。但它不起作用,我没有登录。如何保留cookie并重用它?

这是我的代码:

<?php

// Define the URL and the data you want to send
$loginUrl = 'https://domain.tld/login.php';
$parseUrl = 'https://domain.tld/start.php?page=user';
$loginVars = array(
    'username' => 'user',
    'password' => 'pass'
);

// Now we try to login at the page
$login = curl_init();

curl_setopt( $login, CURLOPT_URL, $loginUrl);
curl_setopt( $login, CURLOPT_POST, 1);
curl_setopt( $login, CURLOPT_POSTFIELDS, $loginVars);
curl_setopt( $login, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt( $login, CURLOPT_HEADER, 1);
curl_setopt( $login, CURLOPT_RETURNTRANSFER, 1);

$loginResponse = curl_exec( $login );

preg_match_all('|Set-Cookie: (.*);|U', $loginResponse, $matches);
$cookies = implode('; ', $matches[1]);

// No we download another page while reusing the cookie

$parse = curl_init();

curl_setopt( $parse, CURLOPT_URL, $parseUrl);
curl_setopt( $parse, CURLOPT_FOLLOWLOCATION, 0);
curl_setopt( $parse, CURLOPT_HEADER, 1);
curl_setopt( $parse, CURLOPT_RETURNTRANSFER, 1);
curl_setopt( $parse, CURLOPT_COOKIE, $cookies);

$parseResponse = curl_exec( $parse );

// Create a DOMDocument for parsing the HTML
$dom = new DOMDocument();
libxml_use_internal_errors(true);
$dom->loadHTML($parseResponse);

// Find the element with an ID of 'username'
$data = $dom->getElementById("username");
echo $data->nodeValue;

curl_close($login);
curl_close($parse);

?>

我怎样才能使这个工作?

2 个答案:

答案 0 :(得分:4)

这应该做的工作:

<?php

//define the cookie file location, make sure cookie.txt has write permissions
$cookiefile = "/your/path/to/cookie.txt";


// Define the URL and the data you want to send
$loginUrl = 'https://domain.tld/login.php';
$parseUrl = 'https://domain.tld/start.php?page=user';
$loginVars = array(
    'username' => 'user',
    'password' => 'pass'
);

// Now we try to login at the page
$login = curl_init();

curl_setopt( $login, CURLOPT_URL, $loginUrl);
curl_setopt( $login, CURLOPT_POST, 1);
curl_setopt( $login, CURLOPT_POSTFIELDS, http_build_query($loginVars));
curl_setopt( $login, CURLOPT_COOKIEJAR, $cookiefile);
curl_setopt( $login, CURLOPT_COOKIEFILE, $cookiefile);
curl_setopt( $login, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt( $login, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt( $login, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt( $login, CURLOPT_HEADER, 1);
curl_setopt( $login, CURLOPT_RETURNTRANSFER, 1);
curl_exec($login);
curl_close($login);

// No we download another page while reusing the cookie

$parse = curl_init();

curl_setopt( $parse, CURLOPT_URL, $parseUrl);
curl_setopt( $parse, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt( $parse, CURLOPT_HEADER, 1);
curl_setopt( $parse, CURLOPT_RETURNTRANSFER, 1);
curl_setopt( $parse, CURLOPT_COOKIEJAR, $cookiefile);
curl_setopt( $parse, CURLOPT_COOKIEFILE, $cookiefile);
curl_setopt( $parse, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt( $parse, CURLOPT_SSL_VERIFYHOST, false);
$parseResponse = curl_exec( $parse );
curl_close($parse);

// Create a DOMDocument for parsing the HTML
$dom = new DOMDocument();
libxml_use_internal_errors(true);
$dom->loadHTML($parseResponse);

// Find the element with an ID of 'username'
$data = $dom->getElementById("username");
echo $data->nodeValue;

?>

备注:

CURLOPT_COOKIEFILE包含cookie数据的文件的名称。 cookie文件可以是Netscape格式,也可以是转储到文件中的普通HTTP样式的标头。如果名称为空字符串,则不会加载cookie,但仍会启用cookie处理。

CURLOPT_COOKIEJAR用于在句柄关闭时保存所有内部Cookie的文件名,例如在调用curl_close之后。

CURLOPT_SSL_VERIFYPEER FALSE阻止cURL验证对等方的证书。可以使用CURLOPT_CAINFO选项指定要验证的备用证书,也可以使用CURLOPT_CAPATH选项指定证书目录。

CURLOPT_SSL_VERIFYHOST 1检查SSL对等证书中是否存在公用名。 2检查是否存在公用名,并验证它是否与提供的主机名匹配。在生产环境中,此选项的值应保持为2(默认值)。

答案 1 :(得分:1)

对于您的两个curl请求($parse$login),请使用以下curl选项设置,并从txt文件中获取Cookie。

$__COOKIE = "c:/var/temp/cookie.txt";
curl_setopt($ch, CURLOPT_COOKIEJAR, $__COOKIE);
curl_setopt($ch, CURLOPT_COOKIEFILE, $__COOKIE);

顺便说一句,我假设你的登录请求是正确的。