我使用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请求。