我需要创建授权脚本。Cookie必须保存并在以后使用才能在未经授权的情况下访问页面。有人能给我举个工作例子吗?
首先,您必须执行一个初始请求以从服务器获取cookie。在响应中,您将把服务器发送的cookie保存在响应标头Set-Cookie
中。你把它们存放在哪里取决于你。我刚刚将它们添加到会话中。
$uri = 'http://example.com';
$client = new Zend_Http_Client();
$client->setUri($uri);
$client->setAdapter('Zend_Http_Client_Adapter_Curl');
$adapter = $client->getAdapter();
$adapter->setCurlOption(CURLOPT_SSL_VERIFYPEER, false);
/** First Request to get required cookies **/
$response = $client->request();
/** Get response cookie strings and store them (session, db, file, etc) **/
$cookies = (array) $response->getHeader('Set-cookie');
$session = new Zend_Session_Namespace();
$session->storedCookies = $cookies;
现在您已经存储了cookie,下次请求时可以将其添加到请求中。
/** Start new Zend_Http_Client instance **/
$uri = 'http://example.com';
$client = new Zend_Http_Client();
$client->setUri($uri);
$client->setAdapter('Zend_Http_Client_Adapter_Curl');
$adapter = $client->getAdapter();
/** This setCurlOption is optional **/
$adapter->setCurlOption(CURLOPT_SSL_VERIFYPEER, false);
$session = new Zend_Session_Namespace();
$cookies = $session->storedCookies;
/** Add Stored Cookie strings to Zend_Http_Client instance **/
foreach ($cookies as $cookieStr) {
$client->setCookie(Zend_Http_Cookie::fromString($cookieStr, $uri));
}
/** Perform request using stored cookies **/
$response = $client->request();
如果你有任何问题或需要我详细说明,请告诉我。