简单实用的数据加密方法

本文介绍了一种基于异或运算的简单加密和解密算法。通过构建特定的加密机,可以对数据进行加密,而利用异或的性质又能轻松解密。文中还提供了具体的C语言实现代码。
异或

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5Glf3B8U-1683016743077)(//img-blog.youkuaiyun.com/20180315183905485?watermark/2/text/Ly9ibG9nLmNzZG4ubmV0L2Rvbmd0dW9j/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)]
上图为运行结果,可以看到数据被解密出来。
如果把加密机中的数据随意写为:
const int EncodeMachine[10] = {0xFE,0xA2,0x41,0x69,0xBC,0xFE,0x7A,0xB8,0x39,0x5A};
可以看到加密的数据毫无规律,但是仍然可以解密出原始数据。

v v v v v v

本文为作者原创,请勿转载,转载请联系作者。
点击下方卡片,关注我的公众号,有最新的文章和项目动态。

v v v v v v

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

董董灿是个攻城狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值