1

我正在尝试编写一个“自动登录”脚本,该脚本使用 curl 登录到特定站点,然后回显响应,以便用户可以“绕过”登录。(例如,授予一次性登录等)

显然,使用下面的方法,cookie是存储在服务器上,而不是客户端上,在cookie.txt中。

我已经尝试设置 $_COOKIE,但这不起作用,因为自动登录脚本的 URL(实际上是子域)和要登录的服务不同。

登录工作正常。您看到的屏幕就像您已登录一样,但单击任何链接都需要您再次登录。

有任何想法吗?谢谢

我用来自动登录的代码:

<?php
$username="email@domain.com"; 
$password="password"; 
$url="http://sub.domain-to-login.com/index.php/sessions/login"; 
$cookie="cookie.txt"; 

$postdata = "email=".$username."&password=".$password.'&btn_login=Login'; 

$ch = curl_init(); 
curl_setopt ($ch, CURLOPT_URL, $url); 
curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
curl_setopt ($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6"); 
curl_setopt ($ch, CURLOPT_TIMEOUT, 60); 
curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1); 
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt ($ch, CURLOPT_COOKIEJAR, $cookie); 
curl_setopt ($ch, CURLOPT_REFERER, $url); 

curl_setopt ($ch, CURLOPT_POSTFIELDS, $postdata); 
curl_setopt ($ch, CURLOPT_POST, 1); 
$result = curl_exec ($ch); 
curl_close($ch);
echo $result;  
?>
4

1 回答 1

0

我想您需要将所有链接(在 $result 中)从http://sub.domain-to-login.com/index.php/stuff替换为http://mysite.com?url=http:/ /sub.domain-to-login.com/index.php/stuff然后使用 curl 再次下载此站点。您只是不能为不同的站点设置 cookie。

于 2013-08-23T14:51:38.780 回答