您的位置:首页 > 其它

简单的加密解密算法

2015-08-21 20:27 716 查看
本文描述一种项目中采用的简单加密解密算法,通过把多种算法进行组合。特点是同个字符串不同时间加密结果不同,混合了多种加密方式,很难用统计的方式对密文进行破解。

项目中仅是对密码进行加密,规定密码长度不超过16个字符,故以下的算法均是固定长度的。

1)扩展字符串

在加密字符串末加"\0",之后添加随机字符串扩展为32个字节。以系统时间为种子产生随机字符串,确保了同个字符串不同时间加密的结果均不同。

2)字符串移位

整个字符串的二进制位依次后移n*8+4位,此操作打乱了字符串的统计特性。

[cpp] view
plaincopy

int n=4;

int i;

char temp
;

for(i=0;i<N;i++)temp[i]=str[i];

for(i=0;i<N;i++)str[i]=((temp[(i+n)%N]<<4)&0xF0)|((temp[(i+n+1)%N]>>4)&0x0F);

3)单字符替换

本操作是把每个字符替换为另一字符,采用算法是把字符的前后4位对调。

[cpp] view
plaincopy

str[i]=((str[i]<<4)&0xF0)|((str[i]>>4)&0x0F);

4)加入密钥进行异或,密钥字符串自定义

5)整个字符串循环移位,原理同2)但操作单位为字符而不是二进制位

以上2)~5)前后顺序可调换,解密过程与加密过程相反。

若需对任意长字符串加密,只需第16字符分别加密然后进行拼接即可。如果需要将密文转换为可见字符进行传输,可对密文进行base64编码。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: