ASIHTTPRequest-Cookie的使用[转]

简介:

ASIHTTPRequest允许你使用全局存储来和所有使用CFNetwork或者NSURLRequest接口的程序共享cookie。

如果设置useCookiePersistence为YES(默认值),cookie会被存储在共享的 NSHTTPCookieStorage 容器中,并且会自动被其他request重用。值得一提的是,ASIHTTPRequest会向服务器发送其他程序创建的cookie(如果这些cookie对特定request有效的话)。

你可以清空session期间创建的所有cookie:

1
[ASIHTTPRequest  setSessionCookies : nil ];

这里的‘session cookies’指的是一个session中创建的所有cookie,而非没有过期时间的cookie(即通常所指的会话cookie,这种cookie会在程序结束时被清除)。

另外,有个方便的函数 clearSession可以清除session期间产生的所有的cookie和缓存的授权数据。 

 

自己处理cookie

如果你愿意,你大可以关闭useCookiePersistence,自己来管理某个request的一系列cookie:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//创建一个cookie
NSDictionary  *properties = [[[ NSMutableDictionary  alloc ]  init ]  autorelease ];
[properties  setValue :[ @ "Test Value"  encodedCookieValue ]  forKey : NSHTTPCookieValue ];
[properties  setValue : @ "ASIHTTPRequestTestCookie"  forKey : NSHTTPCookieName ];
[properties  setValue : @ ".dreamingwish.com"  forKey : NSHTTPCookieDomain ];
[properties  setValue :[ NSDate  dateWithTimeIntervalSinceNow :60 *60 ]  forKey : NSHTTPCookieExpires ];
[properties  setValue : @ "/asi-http-request/tests"  forKey : NSHTTPCookiePath ];
NSHTTPCookie  *cookie = [[[ NSHTTPCookie  alloc ]  initWithProperties :properties]  autorelease ];
 
//这个url会返回名为'ASIHTTPRequestTestCookie'的cookie的值
url = [ NSURL  URLWithString : @ "http://www.dreamingwish.com/" ];
request = [ASIHTTPRequest  requestWithURL :url];
[request  setUseCookiePersistence : NO ];
[request  setRequestCookies :[ NSMutableArray  arrayWithObject :cookie]];
[request  startSynchronous ];
 
//将会打印: I have 'Test Value' as the value of 'ASIHTTPRequestTestCookie'
NSLog ( @ "%@" ,[request  responseString ]);
欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 572064792 | Nodejs:329118122 做人要厚道,转载请注明出处!











本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/sunshine-anycall/p/4135212.html ,如需转载请自行联系原作者



相关文章
|
8月前
|
JSON JavaScript 前端开发
学习 同源策略,jsonp,跨域 随记
学习 同源策略,jsonp,跨域 随记
28 0
|
1月前
|
前端开发
前端Cookie的使用
前端Cookie的使用
16 1
|
4月前
|
移动开发 JavaScript 应用服务中间件
终结同源策略!轻松实现跨域访问的9种方式!
终结同源策略!轻松实现跨域访问的9种方式!
|
9月前
|
JSON 缓存 安全
跨域时怎么处理 cookie?
跨域时怎么处理 cookie?
|
12月前
|
存储 安全 网络协议
还在傻傻分不清cookie和session,cookie与session到底有什么区别?
还在傻傻分不清cookie和session,cookie与session到底有什么区别?
79 0
|
存储 SQL JSON
再谈浏览器存储之 localStorage 和 cookie
WEB 项目的开发,不可避免的要设计存储,这里所说的主要是浏览器存储。之前在文章《WEB 本地存储:localStorage、Web SQL Database、IndexedDB》介绍过浏览器存储。本文之所有再谈浏览器存储,是希望从更加细致的角度出发,并分享存储相关的方法集合。
222 0
|
前端开发 JavaScript
一日一技:前端与后端都是怎么读写 Cookies 的?
一日一技:前端与后端都是怎么读写 Cookies 的?
358 0
一日一技:前端与后端都是怎么读写 Cookies 的?
|
PHP
【laravel】把cookie添加到响应
【laravel】把cookie添加到响应
202 0
【laravel】把cookie添加到响应
|
存储 算法 安全
彻底讲清Web开发的Cookie、Session机制(下)
彻底讲清Web开发的Cookie、Session机制
236 0
彻底讲清Web开发的Cookie、Session机制(下)
|
JavaScript 前端开发 安全
彻底讲清Web开发的Cookie、Session机制(上)
彻底讲清Web开发的Cookie、Session机制
287 0
彻底讲清Web开发的Cookie、Session机制(上)