阅读:2440回复:7
tooflat透明加解密增加RC4算法_源码 问题求解
我下载了tooflat透明加解密增加RC4算法_源码,编译之后测试,出现错误。保存文件时,机器就会死机重启。
有那位大大编译测试成功的啊??能不能分享下经验啊。 个人感觉其中的的加密代码有问题,不知是否正确 for (Offset = 0; Offset < Length; Offset+=1024) { i=(int)memcpy(buffer,((PCHAR)OldBuffer)+Offset,1024); rc4_crypt( s, buffer, i); i=(int)memcpy( ((PCHAR)MyBuffer)+Offset,buffer, i); } 其中i=(int)memcpy能这样使用吗??? 我对其修改 i=Length; for (Offset = 0; Offset < Length; Offset+=1024) { if(i>=1024) { memcpy(buffer,((PCHAR)OldBuffer)+Offset,1024); rc4_crypt( s, buffer, 1024); memcpy( ((PCHAR)MyBuffer)+Offset,buffer,1024); i=i-1024; } else { memcpy(buffer,((PCHAR)OldBuffer)+Offset,i); rc4_crypt( s, buffer, i); memcpy( ((PCHAR)MyBuffer)+Offset,buffer,i); } } 在解密中也类似修改之后。 能够成功加密成密文,但是在解密时出现文件只有前面一部分成功解密成正确的明文,后面的都是乱码,那位大大知道原因吗??指点一下小弟啊,感激不尽。 还有能够使用AES或DES这类分组加密的方式吗??那为有代码能不能发份给我adamas_lwj@163.com ,谢谢了。 |
|
沙发#
发布于:2008-05-03 00:10
这个测试程序里增加了对各种密码算法的支持
http://www.oskrn.com/ |
|
板凳#
发布于:2008-05-03 11:18
i=(int)memcpy是有问题的
memcpy返回类型是size_t int因机器不同而不同的,这样很可能出问题. |
|
|
地板#
发布于:2008-05-03 19:41
哦,那我所修改的加解密有什么问题吗??
为什么我修改好之后解密时出现文件只有前面一部分成功解密成正确的明文,后面的都是乱码的情况,这是为什么啊??? |
|
地下室#
发布于:2008-05-04 23:11
那位大大能够解答一下这个问题啊,在这先感谢了
困扰了我好久啊。。。。。 |
|
5楼#
发布于:2008-05-06 21:00
我继续顶起来,希望那位大大能够指点一下啊。
|
|
6楼#
发布于:2008-05-13 19:56
|
|
7楼#
发布于:2008-05-14 10:44
你说的以512字节为一个Block进行RC4加密,是将我上面所写的代码换成512为一个循环吗??如果是的话,那样我也尝试过啊,还是一样的问题,那是为什么啊?那里有错误吗?
如果不是,那应该则样完成的那,能不能把那部分代码贴出来看看啊,感谢了。 |
|