文章出处:http://blog.csdn.net/delphiwcdj/article/details/6298820

 

具体步骤如下:

(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

 

https://blog.csdn.net/lan120576664/article/details/46045831

posted on 2019-05-31 19:17  瓦楞球  阅读(486)  评论(0编辑  收藏  举报