//联系人:石虎 QQ: 1224614774昵称:嗡嘛呢叭咪哄
01. 用户信息安全
================================================================================
1> 数据安全原则
不能存储(本地&服务器)与安全相关的明文信息
不能直接在网路上传递与安全相关的明文信息
2> BASE64 编码
Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,使用Base64编码后的文件只有65个字符a~z,A~Z,0~9,+,/,=
作用:将任何的二进制数据,编码成字符串/二进制的数据的格式!
特点:能够"逆运算"!
是很多加密算法的底层算法
3> HASH 哈希函数(散列函数)
MD5 - 国内使用多
SHA1 - 美国国家安全局使用较多
原理:把一组数据打乱,提取出特征码,"指纹"识别,不能被反算
* MD5任何数据打乱,都会生成32位固定长度的字符串
* 不仅可以对密码进行加密,而且可以制作文件的指纹,可以防止文件被篡改
MD5密码查询网站 http://www.cmd5.com
记录超过24万亿条,共占用160T硬盘,成功率95%
密码加密的原则:同一个密码,使用同一个加密算法,每次得到的结果是不一样的。
实现思路介绍
02. SSLKeychain
================================================================================
框架地址:https://github.com/soffes/sskeychain
1> 将密码保存至钥匙串
// 用户登录成功,将密码保存到钥匙串
// 提示:钥匙串只能保证密码的存储安全,但是不能保证密码的传输安全
NSError *error = nil;
[SSKeychain setPassword:self.pwdText.text forService:kLoginKeyServiceName account:self.usernameText.text];
if (error) {
NSLog(@"%@", error);
}
2> 从钥匙串读取密码
NSString *pwd = [SSKeychain passwordForService:kLoginKeyServiceName account:self.usernameText.text];
3> 查询钥匙串内容
[SSKeychain allAccounts];
4> 删除钥匙串
[SSKeychain deletePasswordForService:kLoginKeyServiceName account:@"zhangsan"];
03. Cookie
================================================================================
1> 只要服务器支持 Cookie,在下次提交的时候,就可以直接从 Cookie 向服务器发送数据,而无序再拼接请求参数
NSArray *cookies = [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookiesForURL:url];
if (cookies.count > 0) {
NSLog(@"已经有cookie");
} else {
NSString *bodyStr = [NSString stringWithFormat:@"username=%@&password=%@", username, pwd];
request.HTTPBody = [bodyStr dataUsingEncoding:NSUTF8StringEncoding];
}
2> 读取 Cookie 并设置 UI
NSArray *cookies = [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookies];
for (NSHTTPCookie *cookie in cookies) {
if ([cookie.name isEqualToString:@"userName"]) {
self.username.text = cookie.value;
}
if ([cookie.name isEqualToString:@"userPassword"]) {
self.password.text = cookie.value;
}
}
3> 删除 Cookie,一般不需要
// 读取所有cookie
NSArray *cookies = [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookies];
// 删除cookie
for (NSHTTPCookie *cookie in cookies) {
[[NSHTTPCookieStorage sharedHTTPCookieStorage] deleteCookie:cookie];
}
谢谢!!!