异或加密是所有加密中最容易实施且代码量相对精简的一种加密方式,其原理为任意数据被同一个值(key)两次异或后,值不变。
这种特性,使得异或加密算法的加解密流程是完全相同的,也就是说加解密可以用同一个函数实现。
一、算法思路。
依次读入文件字符,并用key值对其异或,结果输入到目标文件中。
二、算法描述。
1 打开源文件及目标文件。
2 获取密钥值(key)。
3 读入一个字符。
4 对其进行异或计算。
5 结果写入目标文件。
6 重复3-5直到文件结尾。
7 关闭文件。
三、代码实现。
为使代码简洁易懂,输入文件设定为in.txt, 输出文件设定为out.txt, key值设首或定为0x5C。
假定所有文件及目录可读写。
#include <stdio.h>#define IN "in.txt"
#define OUT "out.txt"
#define KEY 0x5C
void scrambler(const char *in, const char *out, unsigned char key)
{
FILE *i, *o
int c
清芹毕i = fopen(in, "rb")
o = fopen(out, "wb")//打开文件,因为假定可读写,所以对是否成功不做判断
while((c = fgetc(i))!=EOF)//读入字符直到文件结尾
{
c^=key//执行异或加密或解密
fputc(c,o)//写入文件
}
fclose(i)
fclose(o)
}
int main()
{
scrambler(IN,OUT,KEY)
return 0
}
但是异或加密也是有缺陷的。最大的缺陷是加密 *** 作是二进制层面的,获取到的加密文件大部分将是不可读的乱码。这也是为什么在打开文件的时候要以二进制方式的原因。
鉴答芹于此,在此不便给出测试样例及输入输出,可自行调试。
from random import seed,randintstr_in=input('请输入一尺携个字符串:')
you_seed=input('请输入密码:')
you_seed=int(you_seed)
#lock
def my_lock(lock_str,lock_seed):
seed(lock_seed)
li_out=[]
for i in lock_str:
li_out.append(chr(ord(i)^randint(0,65535)))
return ''.join(li_out)
my_lock_str=my_lock(str_in,you_seed)
print('原字符串:',str_in)
print('加密字符串:',my_lock_str)
print('还原后迹盯字符姿困和串:',my_lock(my_lock_str,you_seed))
input()
#python 3.4
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)