使用curl存储登录响应?

时间:2012-03-05 10:10:43

标签: php scripting curl

我使用网址使用网址,用户名和密码登录网站。主要问题是我想要回复并将其存储在网站已登录的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);
?>

3 个答案:

答案 0 :(得分:1)

如果某个模式/字符串在响应中(保存在strpos(...)中),请与preg_match(...)curl_exec($ch)核对。

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

假设文本(响应的一部分)是Login successful,那么你可以告诉:

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

或者如果您不关心区分大小写

$login_successful = strpos(strtolower($response), "login successful") !== FALSE;
希望有所帮助!

答案 1 :(得分:1)

  

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

成功后应将此值与随附的HTTP代码一起存储在布尔值中。

编辑:

您可以在登录时在第二次cURL调用中使用它。

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

登录后也会接受重定向。

答案 2 :(得分:0)

如果您参考HTTP / 401授权并通过curl登录(而不是POST到表单),您将在失败时再次获得HTTP / 401,如果成功则获得HTTP / 200.

如果“curl”是由PHP脚本驱动的,我建议你直接在PHP中使用来自pear的HTTP_Request启动HTTP请求。