您的位置:首页 > 其它

VS2008下LibTomCrypt 1.17的编译和使用

2011-04-02 16:59 330 查看
2011-04-02 wcdj



具体步骤如下:



(1) 下载tomcrypt

tomcrypt 1.17 VS2008+intel C++工程

http://d.download.csdn.net/down/1783339/jackyjkchen

crypt-1.17.rar (11.03 MB) 源代码

http://www.hackchina.com/cont/118501

Tomcrypt 1.16 and manual

http://download.csdn.net/source/981828

(2) 编译tomcrypt

用VS2008编译tomcrypt 1.17 (第一个下载),然后生成 crypt_s.dll 和 crypt_s.lib 文件。

(3) 在自己的工程中使用tomcrypt

在我们自己的工程中,将 crypt_s.dll 和 crypt_s.lib 文件 分别添加到我们的工程中:

1) 将crypt_s.dll文件直接放在debug目录下,即和工程所生成的可执行文件放在一起。

2) 将crypt_s.lib加入到工程中,方法有三种,这里使用通过代码的方式加入。

3) 将所需要的头文件包含到当前工程中,工程上右键->属性->配置属性->C/C++->附加包含目录

4) 修改编译器设置,工程上右键->属性->配置属性->C/C++->代码生成->运行库,设置为:多线程 DLL (/MD),否则会提示:编译可以通过,但是运行报“找不到MSVCR90.dll”的错误。

(4) 测试:AES加密

/*  
	下面的程序实现的功能: 
	将字符串c1用AES方法加密放在c2中,再解密放在c3中,密钥是myKey  
*/   
#include "tomcrypt.h"
#pragma comment (lib,"crypt_s.lib")
int main(int argc, char* argv[])
{   
    unsigned char myKey[32]= "12345";// 加密密钥  
    symmetric_key skey;// 加密状态
   
    aes_setup(myKey, 32, 0, &skey);// 加密前初始化状态(密钥,密钥长度,迭代次数(0: 使用推荐值),加密状态)
   
   
    unsigned char c1[32]="csdn";// 需要加密的字符串长度任意
    unsigned char c2[32];// 输出长度>= 输入长度,分段长度的倍数(这里就是16的倍数)    
   
    // 分段加密,每段长度为16 (一般不可能只有2段,自己写循环)  
    aes_ecb_encrypt(&c1[0], &c2[0],&skey);   
    aes_ecb_encrypt(&c1[16], &c2[16],&skey);   
   
    unsigned char c3[32];   
    aes_setup(myKey, 32, 0, &skey);// 解密前初始化状态,其实和加密的状态是完全一致的
       
    // 分段解密   
    aes_ecb_decrypt(&c2[0], &c3[0],&skey);   
    aes_ecb_decrypt(&c2[16], &c3[16],&skey); 
	return 0;
}





参考:

调用DLL有两种方法:静态调用和动态调用

http://www.cnblogs.com/c1230v/articles/1401448.html

找不到MSVCR90.dll、Debug vs Release及cppLapack

http://hi.baidu.com/wpzhao/blog/item/72dc08f77ce9be2a730eeca7.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: