Cookie
(1)Cookie由服务器端生成,发送给客户端。
(2)客户端将Cookie的key/value 保存到某个目录下的文本文件内。
(3)如果客户端支持Cookie,下次请求同一网站时就可以Cookie直接发送给服务器。
(4)Cookie名称和值由服务器端开发自己定义。
Cookie 最典型的应用是判定注册用户是否已经登录,记录用户登录信息,简化下次登录的过程。比如:登陆一次不退出下一次不用再登录,Cookie一般只保存0或1判断登录状态。
另外一个最重要的应用场合是“购物车”。可以保存客户添加商品的信息,比如相机等,可以保存一个标示符。
另外需要注意的是Cookie是由服务器端生成并发送给客户端的,我们把本地服务器打开后,并在Sites(存放本地服务器网站的文件夹)中添加login2.html和login2.php ,并用正确的用户名和密码在火狐浏览器进行测试如下所示,登陆后再次重新登录发现生成了Cookie。
为了对比服务器端的login.php和login2.php有何不同 操作步骤如下:
右键Xcode图标——>Open Developer Tool——>FileMerge
选择login.php和login2.php 对比 不同之处如下:
验证如下:
代码如下:
<span style="font-size:18px;">//
// ViewController.m
// Cookie使用
//
// Created by apple on 15/10/29.
// Copyright (c) 2015年 LiuXun. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// 跟踪服务器端返回的Cookie,都在NSHTTPCookieStorage单例对象内。
// 如果服务器端每返回任何Cookie, 就对应一个NSHTTPCookie对象
NSLog(@"%@", [NSHTTPCookieStorage sharedHTTPCookieStorage].cookies);
// 以用户的登录为例进行演示从Cookie里面读取内容
for (NSHTTPCookie *cookie in [NSHTTPCookieStorage sharedHTTPCookieStorage].cookies) {
// 数组里面存放的是NSHTTPCookie对象
// NSHTTPCookie对象里面有个properties属性字典
// 字典里userName对应的值,就是服务器返回的cookie的内容
// 字典里userPassword对应的值,就是服务器返回的cookie的内容
NSLog(@"%@", cookie.properties);
if ([cookie.name isEqualToString:@"userName"]) {
NSLog(@"记录的用户名 %@", cookie.value);
}else if ([cookie.name isEqualToString:@"userPassword"])
{
NSLog(@"记录的密码 %@", cookie.value);
}
}
}
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
// 1. url
NSURL *url = [NSURL URLWithString:@"http://127.0.0.1/login2.php"];
// 2. 请求
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url cachePolicy:1 timeoutInterval:2.0f];
// 2.1
request.HTTPMethod = @"POST";
// 2.2 设置数据体
// NSString *body = @"username=zhangsan&password=zhang";
//
// request.HTTPBody = [body dataUsingEncoding:NSUTF8StringEncoding];
// 3. 连接
[NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
NSError *error =nil;
id result = [NSJSONSerialization JSONObjectWithData:data options:0 error:&error];
if (error) {
NSLog(@"%@", [error localizedDescription]);
}
NSLog(@"%@", result);
}];
}
@end</span>
第一次发送数据体,运行结果如下:
打开沙盒路径发现生成了Cookies文件夹,打开如下:
使用终端打开此Cookies文件夹内的文件如下:
第二次不发送数据体,重新运行如下:
说明第二次是客户端直接从沙盒Cookie文件中读取的第一次服务器端发送的Cookie信息。
另外 发现Cookie存放的是明文,不安全。只能存放一些别的信息,比如登录状态0或1 购物车等不涉及用户隐私的信息。那么如何判断并跟踪服务器发送到客户端的Cookies呢?
跟踪服务器端返回的Cookie都在NSHTTPCookieStorage单例对象内,每当服务器返回一个Cookie,就对应着一个NSHTTPCookie对象。NSHTTPCookieStorage单例对象的获取方法如下:
+ (NSHTTPCookieStorage *)sharedHTTPCookieStorage;
此单例对象有一个cookies属性数组,数组内的每一个元素都是每一个NSHTTPCookie对象
@property (readonly,copy)NSArray *cookies;
每一个NSHTTPCookie对象都有一个只读的properties字典属性
@property (readonly,copy)NSDictionary *properties;
每一个properties字典属性里都有一个name和value属性,与服务器端的Cookie相对相应。具体使用如下:
//以用户的登录为例进行演示从Cookie里面读取内容
for (NSHTTPCookie *cookiein [NSHTTPCookieStoragesharedHTTPCookieStorage].cookies) {
//数组里面存放的是NSHTTPCookie对象
// NSHTTPCookie对象里面有个properties属性字典
//字典里userName对应的值,就是服务器返回的cookie的内容
//字典里userPassword对应的值,就是服务器返回的cookie的内容
NSLog(@"%@", cookie.properties);
if ([cookie.nameisEqualToString:@"userName"]) {
NSLog(@"记录的用户名 %@", cookie.value);
}elseif ([cookie.nameisEqualToString:@"userPassword"])
{
NSLog(@"记录的密码 %@", cookie.value);
}
}
打印Cookies内容,并取出指定的内容如下:
本文详细介绍了Cookie的工作原理及在Web开发中的应用,包括登录状态管理、购物车功能实现,以及如何通过代码示例追踪和读取服务器端返回的Cookie。重点强调了Cookie的安全限制及其适用场景。
2267

被折叠的 条评论
为什么被折叠?



