使用curl存储登录的响应


Storing the response of login using curl?

我使用curl使用url、用户名和密码登录了一个网站。主要的问题是,我想取回响应并将其存储在php脚本中,该脚本表明该网站是否已登录?

主要问题是在php脚本中存储响应,即登录或登录失败?我已经给出了下面的脚本,你能告诉我要添加什么吗?

提前感谢

<?php
$cookiefile = tempnam("/tmp", "cookies");
$login_url='**********';

$login_post_url='*********';

$username = "*****";
$password = "*****";
$agent="Mozilla/5.0 (Windows NT 5.1; rv:10.0.2) Gecko/20100101 Firefox/10.0.2 ";

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$login_url);
curl_setopt($ch, CURLOPT_USERAGENT, $agent);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookiefile);
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookiefile);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,  2);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$result = curl_exec ($ch);

curl_close ($ch);

$postfields = array(
        'j_username' => $username,
        'j_password' => $password,
    );
$reffer = $login_url;
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$login_post_url);
curl_setopt($ch, CURLOPT_USERAGENT, $agent);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS,
       http_build_query($postfields));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_REFERER, $reffer);

curl_setopt($ch, CURLOPT_COOKIEFILE, $cookiefile);
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookiefile);

curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,  2);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$result = curl_exec ($ch);
 echo $result;
curl_close ($ch);

unlink($cookiefile);
?>

只需使用strpos(...)preg_match(...)检查响应中是否存在某个模式/字符串(保存在curl_exec($ch)中)。

之后,只需保存您正在使用的cookie的名称,之后当您再次运行此脚本时,就不需要再次登录。

假设文本(响应的一部分)是Login successful,那么您可以判断:

$login_successful = strpos($response, "Login successful") !== FALSE;

或者如果你不在乎区分大小写的

$login_successful = strpos(strtolower($response), "login successful") !== FALSE;

希望能有所帮助!

主要问题是在php脚本中存储响应,即登录或登录失败?

成功时,应将其存储在一个布尔值中,并附带HTTP代码。

编辑:

您可以在登录时的第二次cURL调用中使用此选项。

$httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
$loginSuccess = $httpCode >= 200 && $httpCode < 400;

这也将在登录后接受重定向。

如果您通过curl引用HTTP/401授权和登录(而不是对表单进行POST),如果失败,您将再次获得HTTP/401,如果成功,您将获得HTTP/200。

如果"curl"是由PHP脚本驱动的,我建议您使用例如来自pear的HTTP_request直接在PHP内部启动HTTP请求。