关于算法:异或算法简单实用的数据加密方法

5次阅读

共计 837 个字符,预计需要花费 3 分钟才能阅读完成。

异或

异或算法的益处便是数 A 和数 B 异或后,把后果再和数 A 异或便可失去 B,或者和数 B 异或可重新得到数据 A。利用异或的这个个性可简略实现数据的加密和解密算法。

构建加密机加密

加密机实际上便是异或中的其中一个数,能够依据本人的须要随便构建。例如我能够构建如下加密机:

const int EncodeMachine[10] = {0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0A};

我须要加密的数据为:

int RawData[10] = {0x68, 0x12, 0x34, 0x56, 0x78, 0x89, 0x0A, 0X0B, 0X0C, 0X0D};

只须要执行如下算法即可

#define MAX_TEST_NUM 10;
int main()
{int EncodeData[MAX_TEST_NUM] = {0};
    int DecodeData[MAX_TEST_NUM] = {0};
    int i;

    printf("加密数据为:");
    for (i=0;i<MAX_TEST_NUM;i++)
    {EncodeData[i] = RawData[i]^EncodeMachine[i];
        printf("0x%02x",EncodeData[i]);
    }

    printf("\r\n");
    
    printf("解密数据为:");
    for(i=0;i<MAX_TEST_NUM;i++)
    {DecodeData[i] = EncodeData[i]^EncodeMachine[i];
        printf("0x%02x",DecodeData[i]);
    }
}

残缺内容请点击下方链接查看:
异或算法——简略实用的数据加密办法

版权申明:本文内容由阿里云实名注册用户自发奉献,版权归原作者所有,阿里云开发者社区不领有其著作权,亦不承当相应法律责任。具体规定请查看《阿里云开发者社区用户服务协定》和《阿里云开发者社区知识产权爱护指引》。如果您发现本社区中有涉嫌剽窃的内容,填写侵权投诉表单进行举报,一经查实,本社区将立即删除涉嫌侵权内容。

正文完
 0