的Cookie问题(PHP) - 在卷曲头
我有这样的代码的Cookie问题(PHP) - 在卷曲头
<?php
$mLoginUrl = "https://www.test.com/login";
$mCookieFile = dirname(__FILE__).'/tmpCookies/cookie'.rand().'.txt';
define('USER_AGENT', 'Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.2309.372 Safari/537.36');
define('COOKIE_FILE', $mCookieFile);
define('LOGIN_FORM_URL', $mLoginUrl);
define('LOGIN_ACTION_URL', $mLoginUrl);
$postValues = array(
'user[email]' => "[email protected]",
'user[password]' => "mypassword"
);
$headers = Array(
"Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5",
"Cache-Control: max-age=0",
"Connection: keep-alive",
"Keep-Alive: 300",
"Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7",
"Accept-Language: en-us,en;q=0.5",
"Pragma: "
);
$curl = curl_init();
curl_setopt($curl, CURLOPT_VERBOSE, TRUE);
curl_setopt($curl, CURLOPT_URL, LOGIN_ACTION_URL);
curl_setopt($curl, CURLOPT_POST, TRUE);
curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($postValues));
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER,FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($curl, CURLOPT_COOKIEJAR, COOKIE_FILE);
curl_setopt($curl, CURLOPT_COOKIEFILE, COOKIE_FILE);
curl_setopt($curl, CURLOPT_USERAGENT, USER_AGENT);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($curl, CURLOPT_REFERER, LOGIN_FORM_URL);
curl_setopt($curl, CURLOPT_FOLLOWLOCATION, TRUE);
curl_setopt($curl, CURLOPT_HTTPHEADER,$headers) ;
curl_setopt($curl, CURLINFO_HEADER_OUT, TRUE);
$res = curl_exec($curl);
$info = curl_getinfo($curl);
print_r($info['request_header']);
exit;
?>
这工作得很好我的本地计算机上和我的服务器和节目之一下面的输出未连接的Cookie信息
GET/HTTP/1.1
User-Agent: Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.2309.372 Safari/537.36
Host: www.test.com
Referer: https://www.test.com/login
Cookie: _property_session=WjROWEYvTHNYaE5Zb29jVk04WGM0Z3FybmhmY1ZIeVdBc2N6d2N3UmViaXlZdFNhR1dSbUN4QVh6aFFSRjFPYktybmdnRGlXNG0yWWcremEzcklKTnE1ZE1lTTM0eUQrSG90SVhRRzhvYW5rWmFQTVhBMjVCWjBtb1FSc0RrTEh2RjhHSFI3aHkwa3U4N3Y3czJhTzJuN2ZGbWRRN0Nra2Z6OTR4aHhvVG42bVVRS3kwTExUL1hMN2JoZ0xRd2g3VVdIMC81cGhLQzJjOTJvc2RYajIwakE0VjZqRnhTeHBleFltTGF4Z3hpUGJEb0E3Nlo2S3BwMElqNnVkaWhDVS0tc0pCRlozSVE5bXRHQXlHWE1IbTl4UT09--67cf6e056b84b4cae4d275507f544927802eb78d
Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5
Cache-Control: max-age=0
Connection: keep-aliveKeep-Alive: 300 Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Accept-Language: en-us,en;q=0.5
这意味着cookie已创建并附加在CURL的标题中(正如我们可以在上面的CURL头文件中看到的一样).Cookie文件也在所提及的位置创建。
但在我的服务器代码不按预期工作之一,并给出了下面的输出
POST /users/sign_in? HTTP/1.1 User-Agent: Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.2309.372 Safari/537.36 Host: www.test.com Referer: https://www.test.com/login Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5 Cache-Control: max-age=0 Connection: keep-alive Keep-Alive: 300 Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Accept-Language: en-us,en;q=0.5 Content-Length: 76 Content-Type: application/x-www-form-urlencoded
意味着cookie信息不卷曲头连接。我已经检查过,在这个(有问题的)服务器中也创建了cookie文件,并且有cookie内容,但cookie内容不包含在CURL头文件中。提到的临时cookie目录对所有用户具有完整的权限/许可(777)。
在有问题的服务器上,PHP版本是5.4.19,CURL版本是7.19.7。
如果有人能帮忙吗?我尝试了所有在互联网上找到的解决方案。
在此先感谢。
感谢所有您的帮助。我解决了问题。问题是open_basedir路径。我在解决问题的服务器上将此设置为“无”。
$mCookieFile = dirname(__FILE__).'/tmpCookies/cookie'.rand().'.txt';
删除兰特()...是一个静态文件
谢谢。有效。我的意思是现在提到静态文件名后附上Cookie信息,但仍然无法登录到其他网站。结果虽然有一点点差异。在开始时有** POST/login?**而不是** GET **。 这也可以在我的主要问题中指出,一个是有GET和其他有POST。为什么这样呢?任何帮助?请 –
您的代码发出请求并尝试通过Chrome登录并在Chrome中查看 - 检查 - >网络发送什么参数 – CatalinB
我已将Chrome-> Inspect-> Network上传到以下图片。看看你能否帮忙。为什么一个是GET而另一个是POST如果代码相同? GET正在工作http://imgur.com/a/Tfeka –
通过提及CatalinB建议的静态文件名称我能够在标头中获取Cookie信息,但仍然无法登录到其他网站。结果虽然有一点点差异。在开始时有** POST/login?**而不是** GET **。 这也可以在我的主要问题中指出,一个是有GET和其他有POST。为什么这样呢?任何帮助?请 –