一:.Base64补充

```objc

1.Base64简单说明

描述:Base64可以成为密码学的基石,非常重要。

特点:可以将任意的二进制数据进行Base64编码

结果:所有的数据都能被编码为并只用65个字符就能表示的文本文件。

65字符:A~Z a~z 0~9 + / =

对文件进行base64编码后文件数据的变化:编码后的数据~=编码前数据的4/3,会大1/3左右。

2.命令行进行Base64编码和解码

编码:base64 123.png -o 123.txt

解码:base64 123.txt -o test.png -D

2.Base64编码原理

1)将所有字符转化为ASCII码;

2)将ASCII码转化为8位二进制;

3)将二进制3个归成一组(不足3个在后边补0)共24位,再拆分成4组,每组6位;

4)统一在6位二进制前补两个0凑足8位;

5)将补0后的二进制转为十进制;

6)从Base64编码表获取十进制对应的Base64编码;

处理过程说明:

a.转换的时候,将三个byte的数据,先后放入一个24bit的缓冲区中,先来的byte占高位。

b.数据不足3byte的话,于缓冲区中剩下的bit用0补足。然后,每次取出6个bit,按照其值选择查表选择对应的字符作为编码后的输出。

c.不断进行,直到全部输入数据转换完成。

d.如果最后剩下两个输入数据,在编码结果后加1个“=”;

e.如果最后剩下一个输入数据,编码结果后加2个“=”;

f.如果没有剩下任何数据,就什么都不要加,这样才可以保证资料还原的正确性。

3.实现

a.说明:

1)从iOS7.0 开始,苹果就提供了base64的编码和解码支持

2)如果是老项目,则还能看到base64编码和解码的第三方框架,如果当前不再支持iOS7.0以下版本,则建议替换。

b.相关代码:

//给定一个字符串,对该字符串进行Base64编码,然后返回编码后的结果

-(NSString *)base64EncodeString:(NSString *)string

{

//1.先把字符串转换为二进制数据

NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding];

//2.对二进制数据进行base64编码,返回编码后的字符串

return [data base64EncodedStringWithOptions:0];

}

//对base64编码后的字符串进行解码

-(NSString *)base64DecodeString:(NSString *)string

{

//1.将base64编码后的字符串『解码』为二进制数据

NSData *data = [[NSData alloc]initWithBase64EncodedString:string options:0];

//2.把二进制数据转换为字符串返回

return [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];

}

c.终端测试命令

$ echo -n A | base64

$ echo -n QQ== |base64 -D

```

二:加密学习:

加密相关

```objc

网络应用程序数据的原则:

1. 在网络上"不允许"传输用户隐私数据的"明文"

2. 在本地"不允许"保存用户隐私数据的"明文"

加密相关

1. base64 编码格式

2. 密码学演化 "秘密本"-->RSA

RSA简单说明:加密算法算法是公开的,加密方式如下:

- "公钥"加密,"私钥"解密

- "私钥"加密,"公钥"解密

目前流行的加密方式:

---------------

- 哈希(散列)函数

- MD5

- SHA1

- SHA256

- 对称加密算法

- DES

- 3DES

- AES(高级密码标准,美国国家安全局使用的)

- 非对称加密算法(RSA)

散列函数:

---------------

特点:

- 算法是公开的

- "对相同的数据加密,得到的结果是一样的"

- 对不同的数据加密,得到的结果是定长的,MD5对不同的数据进行加密,得到的结果都是 32 个字符长度的字符串

- 信息摘要,信息"指纹",是用来做数据识别的!

- 不能反算的

用途:

- 密码,服务器并不需要知道用户真实的密码!

- 搜索

张老师 杨老师 苍老师

苍老师 张老师 杨老师

张老师            1bdf605991920db11cbdf8508204c4eb

杨老师             2d97fbce49977313c2aae15ea77fec0f

苍老师             692e92669c0ca340eff4fdcef32896ee

如何判断:对搜索的每个关键字进行三列,得到散个相对应的结果,按位相加结果如果是一样的,那搜索的内容就是一样的!

- 版权

版权保护,文件的识别。

破解:

- http://www.cmd5.com 记录超过24万亿条,共占用160T硬盘 的密码数据,通过对海量数据的搜索得到的结果!

提升MD5加密安全性,有两个解决办法

1. 加"盐"(佐料)

2. HMAC:给定一个"秘钥",对明文进行加密,并且做"两次散列"!-> 得到的结果,还是 32 个字符

#import "ViewController.h"
#import "NSString+Hash.h" //足够长+足够咸+足够复杂
#define salt @"shdcskjfcbskfnslfhs.kfsfvmsf8348390(*^^6R%@@IJEKHRKWKFGKF" @interface ViewController () @end @implementation ViewController
/**
* 1:MD5加密是不可逆的,一般都需要:明文 + 加盐 +乱序 :相对来说不容易破解
*
*/
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{ //(明文+加盐)MD5 NSLog(@"%@",[@"520it" md5String]);
NSLog(@"%@",[[@"520it" stringByAppendingString:salt] md5String]); //先加密+乱序
//cb0fe21bfcc4c2625469d8ec6f3d710d--->12345 NSLog(@"%@",[@"520it" hmacMD5StringWithKey:@"xiaomage"]); // NSLog(@"%@",[self base64EncodeString:@"A"]);
// NSLog(@"%@",[self base64DecodeString:@"QQ=="]);
} //对一个字符串进行base64编码,并且返回
-(NSString *)base64EncodeString:(NSString *)string
{
//1.先转换为二进制数据
NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding]; //2.对二进制数据进行base64编码,完成之后返回字符串
return [data base64EncodedStringWithOptions:];
} //对base64编码之后的字符串解码,并且返回
-(NSString *)base64DecodeString:(NSString *)string
{
//注意:该字符串是base64编码后的字符串
//1.转换为二进制数据(完成了解码的过程)
NSData *data = [[NSData alloc]initWithBase64EncodedString:string options:]; //2.把二进制数据在转换为字符串
return [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
}
@end

ios开发Base64编码以及加密相关学习的更多相关文章

  1. 李洪强iOS开发Swift篇---12_NSThread线程相关简单说明

    李洪强iOS开发Swift篇---12_NSThread线程相关简单说明 一 说明 1)关于多线程部分的理论知识和OC实现,在之前的博文中已经写明,所以这里不再说明. 2)该文仅仅简单讲解NSThre ...

  2. Python中的Base64编码的加密与解密

    Base64 可以干些啥? Base64编码的作用: 由于某些系统中只能使用ASCII字符.Base64就是用来将非ASCII字符的数据转换成ASCII字符的一种方法. 图片(and种子)base64 ...

  3. iOS base64编码 MD5 加密

    //创建一个Base64编码的NSString对象 //字符串 转二进制 NSData *nsdata = [@"iOS Developer Tips encoded in Base64&q ...

  4. ios开发之--编码及命名规范

    做了几年的开发工作,因为是半路出的家,所以对这块一直都没怎么重视,所以在工作中,出现了很多的尴尬场景,编码和命名的规范是一定得有的,最起码一个团队之间的规范也是很有必要的.面向对象的编程,其实很好理解 ...

  5. ios开发FMDB导入SQLCipher加密数据库

    转:http://www.2cto.com/kf/201407/315727.html [iOS]FMDB/SQLCipher数据库加解密,迁移

  6. ios中base64编码

    参考文章:其中文章的:http://blog.csdn.net/ztp800201/article/details/9470065 下载包 其中 包括GTMBase包下载地址 http://pan.b ...

  7. ios开发--NSDate与NSDateFormatter的相关用法【转】

    原文地址:http://blog.sina.com.cn/s/blog_91ff71c0010188u9.html 1.NSDateFormatter配合NSDate与NSString之间的转化  N ...

  8. iOS开发--iOS及Mac开源项目和学习资料

    文/零距离仰望星空(简书作者)原文链接:http://www.jianshu.com/p/f6cdbc8192ba著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 原文出处:codecl ...

  9. iOS开发学习 阶段过程简述

    下面就简单介绍一下我iOS开发的感受,也是学习iOS开发的一个体系架构. 1 iOS开发环境 1.1 开发环境 标准的配置是Mac OS X + Xcode. MacOSX的话首选用苹果电脑,macm ...

随机推荐

  1. iOS - 系统经常使用框架(framework)的简介

    系统框架(framework)的简介 ImageIO  - 该框架的接口可用于导入或导出图像数据及图像元数据 CoreTelephony  - 获取IMSI号,SIM卡背面的号码是SIM卡的电子串号, ...

  2. 前6名免费DNS服务 - 公共DNS服务

    前6名免费DNS服务 - 公共DNS服务 谷歌 8.8.8.8,8.8.4.4备份,用户将期望并获得高可用性,如DNSSEC等过滤和安全保护. OpenDNS 现在是Cisco帝国的一部分,主要是20 ...

  3. index action分析

    上一篇从结构上分析了action的,本篇将以index action为例仔分析一下action的实现方式. 再概括一下action的作用:对于每种功能(如index)action都会包括两个基本的类* ...

  4. HDU 1548 A strange lift(最短路&&bfs)

    A strange lift Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)To ...

  5. POJ Fence Repair(优先队列)

    Fence Repair Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 51346   Accepted: 16857 De ...

  6. Codeforces Round #194 (Div. 2) 部分题解

    http://codeforces.com/contest/334 A题意:1-n^2 平均分成 n 份,每份n个数,且和相同 解法 : 构造矩阵1-n^2的矩阵即可 ][]; int main() ...

  7. BZOJ3238: [Ahoi2013]差异(后缀数组)

    Description Input 一行,一个字符串S Output 一行,一个整数,表示所求值 Sample Input cacao Sample Output 54 解题思路: 看到lcp,想到了 ...

  8. 解决ListCtrl控件第一列文字不能居中显示的问题/修改网格线

    把CListCtrl设置为Report风格,但是插入第一列的时候(InsertColumn)的时候会发现文字不能居中.即使使用了LVCFMT_CENTER,其他列都可以正常居中,但第一列仍然靠左显示. ...

  9. 洛谷 P2819 图的m着色问题

    P2819 图的m着色问题 题目背景 给定无向连通图G和m种不同的颜色.用这些颜色为图G的各顶点着色,每个顶点着一种颜色.如果有一种着色法使G中每条边的2个顶点着不同颜色,则称这个图是m可着色的.图的 ...

  10. HTML基础第十讲---排版卷标

    转自:https://i.cnblogs.com/posts?categoryid=1121494 网页的排版部份也是很重要的一环,有些现成的卷标就可以让您轻易的完成缩排或是一些特殊格式的编排喔! [ ...