iOS 异或加密(XOR)

作者: 阶前梧叶 | 来源:发表于2016-11-02 18:11 被阅读2770次

    原文链接
    源码见文末

    异或简介

    • 异或,二元运算;
    • 符号^;
    • 口诀:相同为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源码

    相关文章

      网友评论

        本文标题:iOS 异或加密(XOR)

        本文链接:https://www.haomeiwen.com/subject/byzvuttx.html