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