简单实用的数据加密方法

版权声明:本文为博主原创文章,未经博主允许不得转载。有任何问题欢迎留言或加好友交流。 https://blog.csdn.net/dongtuoc/article/details/79572173

异或

异或算法的好处便是数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]);
    }
}

这里写图片描述
上图为运行结果,可以看到数据被解密出来。
如果把加密机中的数据随意写为:
const int EncodeMachine[10] = {0xFE,0xA2,0x41,0x69,0xBC,0xFE,0x7A,0xB8,0x39,0x5A};
可以看到加密的数据毫无规律,但是仍然可以解密出原始数据。
这里写图片描述

阅读更多
换一批

没有更多推荐了,返回首页