iOS 异或加密(XOR)

2017-01-14 10:21:25来源:http://www.jianshu.com/p/a8098dfb1840作者:阶前梧叶人点击

原文链接
源码见文末


异或简介

异或,二元运算;
符号^;
口诀:相同为0,不相同为1;
举例
10011101^10001010=00010111

应用场景
密码加密(此场景在日常开发中使用较多,本文将着重介绍此应用场景)
数据暂存
嵌入式

异或加密原理
假设明文A, 密钥B, 密文C,
通过异或加密过程为A ^ B = C, 得到密文C
如果此时知道密文A和密钥B,那么通过异或解密过程为C ^ B = A, 重新得到明文A

异或加密

异或加密应用
企业由于数据具有保密性,需要对敏感数据进行加密。 数据存在的形式可能是客户端的缓存、内置资源文件、网络传输等,这些数据都有可能被用户,竞争对手,黑客截获的潜在风险;通过加密可以进行规避,异或加密是其中较为简单的一种实现方案。
例如某公司App要内置一些核心资源配置文件,为防止用户窥探,采用了加密处理,先将方案分享如下:
后端生成配置文件时,用私钥对数据进行异或运算处理,生成密文;客户端拿到密文,通过自动或手动打包的app中,app在运行时,采用相同的密钥、按照相同的算法进行异或运算,得到明文,进而使用。
异或算法
假设 私钥abcdefg7位,将数据转换为data类型,获取所有字节;将字节每七位分别于私钥七位字符异或运算,一直循环到最后得到密文
异或解密算法和加密算法一致,即通过这个算法运行一次是加密,再通过这个算法运行一次就是解密


iOS代码实现
// 客户端内置私钥
static NSString const *privateKey = @"ef37c9111210854f5986fc9ebb5548b2ae";
@implementation NSData(XOREncrypt)
- (NSData *)xor_decrypt
{
return [self xor_encrypt];
}
// 加密
- (NSData *)xor_encrypt
{
// 获取key的长度
NSInteger length = privateKey.length;
// 将OC字符串转换为C字符串
const char *keys = [privateKey cStringUsingEncoding:NSASCIIStringEncoding];
unsigned char cKey[length];
memcpy(cKey, keys, length);
// 数据初始化,空间未分配 配合使用 appendBytes
NSMutableData *encryptData = [[NSMutableData alloc] initWithCapacity:length];
// 获取字节指针
const Byte *point = self.bytes;
for (int i = 0; i < self.length; i++) {
int l = i % length; // 算出当前位置字节,要和密钥的异或运算的密钥字节
char c = cKey[l];
Byte b = (Byte) ((point[i]) ^ c); // 异或运算
[encryptData appendBytes:&b length:1]; // 追加字节
}
return encryptData.copy;
}
@end

思考题
int a = 15;
int b = 20;

不用第三个变量,交换两个变量的值?


答案(面试装13用)
int a = 15;
int b = 20;
a = a ^ b;
b = a ^ b;
a = a ^ b;

源码

XORDemo源码




最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台