我正在尝试通过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);
?>
我怎样才能使这个工作?
答案 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);
顺便说一句,我假设你的登录请求是正确的。