数据安全

一.Base64编码

1.概念

Base64编码是一种对二进制数据编码的方式,可以把源数据(文本,图片,视频音频等数据)编码成64个字符表示的文本数据。

2.iOS实现

先看看ios中对数据进行Base64编码解码

    //对字符串"A"Base64编码
    NSData * bdata=[@"A" dataUsingEncoding:NSUTF8StringEncoding];
    NSString *base64data=[bdata base64EncodedStringWithOptions:kNilOptions];
    
    NSLog(@"%@",base64data);//输入结果:QQ==
    //对字符串"A"Base64解码
    NSData * adata=[[NSData alloc]initWithBase64EncodedString:base64data options:kNilOptions];
    NSString * restr=[[NSString alloc]initWithData:adata encoding:NSUTF8StringEncoding];
    NSLog(@"%@",restr);//输入结果:A
3.原理

这64个字符包括字母A-Z、a-z、数字0-9 、+/


1529487684246.jpg

编码的方式简单说就是把源数据的二进制(一个字符8位)变成6位一组,然后对应到编码表相应字符,不够的用0补齐,至少使用6*4=24位4组,如果该组全是空,则对应"="。
所以编码之后的数据大概是源数据8/6倍。
举例说明:
Man---Base64编码--->TWFu
A---Base64编码--->QQ==
BC---Base64编码--->QkM=


WX20180620-174559.png

二.散列函数(Hash算法)

1.特点

属于不可逆加密算法,速度快,效率高
对源文件进行加密,无论源文件大小,加密结果定长
源文相同,密文相同;源文不同,密文不同
具体常见方式:MD5, SHA1, SHA256, SHA512

2.应用

找回密码不是真正找回密码,而是重置密码;
比较两个大文件数据是否一致,可以比较Hash算法之后的散列结果;
文件传输时,防止过程被篡改,可以打一个Hash算法之后的结果,然后拿到之后再进行Hash算法比较。

3.MD5加密方式

1.密码直接MD5加密
特点:可以直接被暴力破解
2.(密码+盐)MD5加密
特点:多组数据比较可能得到盐,而且没有拓展性
3.(密码乱序)MD5加密
特点:相对安全,但没有拓展性
4.密码MD5加密再截取部分
特点:相对安全,但没有拓展性
5.密码MD5+HMAC
特点:两次加密

三.对称加密

1.概念

加密解密使用同样的密钥

2.经典算法

DES 1个密钥
3DES 3个密钥 (密钥1+加密 密钥2+解密 密钥3+加密)
AES 高级加密标准

3.原理

分组加密和流加密,DES,3DES,AES都使用分组加密方式。
分组加密:ECB和CBC方式
ECB(电子密码本):加密时,把源数据进行分组加密,然后拼接在一起;解密时,把加密数据进行分组解密,然后拼接在一起;相同的源数据进行加密结果都一样,如果源数据中间出现一段修改,那么加密也是中间一部分数据不同。
CBC:同样是分组加密解密,但是下一个分组加密依赖于上一个分组数据;如果源数据中间出现一段修改,那么加密结果从这部分开始都不一样。
流加密

4.缺陷

传输过程中密钥可能被截取;如果写到本地又不够灵活。

四.非对称加密

1.概念

加密解密使用不同的密钥,加密用公钥,解密用私钥。安全但是性能差

2.经典算法

RSA

3.原理

服务器端生成私钥,然后通过私钥生成对应的公钥,把公钥发送给客户端,客户端用该公钥加密数据,然后服务器用私钥解密数据。(之所以能用不同密钥加密解密是数学问题,暂不探讨)
其中有一个安全隐患是,公钥在传输过程中可能被中间黑客捕获,然后仿造公钥和私钥,把仿造的公钥发送给客户端,客户端并不知道,那么用仿造的公钥发出数据,再被中间黑客捕获,用仿造的私钥就可以破解客户端信息。
所以由此而生的就是证书,而不单纯是字符串公钥私钥。
证书=公钥+数字签名,能够保证客户端拿到的公钥是服务器端的证书,而不是篡改的证书。
数字签名可以是CA颁布的(付费),当然也可以是自己签名的(某宝可买),区别就在于CA被国际承认,但是自己签名的并不代表不安全(浏览器认为你不安全而已)。

https://github.com/mddios/EncryptionTools

五.HTTPS

1.HTTPS原理

类似于非对称加密的方式;
简单说就是客户端向服务器发送请求,服务器会给客户端一个证书,客户端检验证书合法性,如果合法,则从证书中提取出公钥进行数据加密,然后服务器用私钥进行解密,完成通讯。
具体可参考:
https://www.jianshu.com/p/33feb2fadb15

2.iOS中使用HTTPS注意事项

如果HTTPS证书受信任(权威机构eg:CA颁发),则不用做任何处理。

如果HTTPS证书不受信任(自签名),则需要做一些处理。
首先info.plist修改配置信息


WX20180621-164132.png

其次如果是AFN,做安全配置

    //允许无效证书+不做域名验证
    manager.securityPolicy.allowInvalidCertificates=YES;
    manager.securityPolicy.validatesDomainName=NO;

如果是NSURLSession,实现NSURLSessionDelegate代理didReceiveChallenge

-(void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition, NSURLCredential * _Nullable))completionHandler
{
    /*
     NSURLSessionAuthChallengeUseCredential = 0,  使用证书
     NSURLSessionAuthChallengePerformDefaultHandling = 1, 忽略证书
     NSURLSessionAuthChallengeCancelAuthenticationChallenge = 2, 取消请求
     NSURLSessionAuthChallengeRejectProtectionSpace = 3, 拒绝证书
     */
    NSURLCredential * credential=[[NSURLCredential alloc]initWithTrust:challenge.protectionSpace.serverTrust];
    completionHandler(NSURLSessionAuthChallengeUseCredential,credential);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,651评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,468评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,931评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,218评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,234评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,198评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,084评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,926评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,341评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,563评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,731评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,430评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,036评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,676评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,829评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,743评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,629评论 2 354