VS2017编译OpenSSL 1.0.2O

1.先下载ActivePerl.并安装

2.下载OpenSSL

3. 点击 windows 开始->所有应用->vs2017->x86 Native Tools Command Prompt for VS 2017

4. CD到解压后的openssl的根目录。

5. 执行命令:perl Configure VC-WIN32 no-asm 或 perl Configure VC-WIN64A no-asm【64位。但上面需要选x64工具打开】

perl Configure debug-VC-WIN32 no-asm生成debug版本。


6. ms\do_ms     [64]ms\do_win64a.bat

7. 执行nmake -f ms\ntdll.mak(编译动态库)。

8. 执行nmake -f ms\ntdll.mak test查看库是否有问题。

9. 执行nmake -f ms\ntdll.mak install  讲openssl安装到--prefix指定的文件夹。

好吧上面是抄袭别人的。

来源网址:

https://www.cnblogs.com/johngu/p/8023549.html

https://blog.csdn.net/tianse12/article/details/72844231

==编译动态库和静态库 
运行 nmake -f ms\ntdll.mak进行编译动态库 
运行 nmake -f ms\nt.mak进行编译静态库 

=============如果有0x2 什么警告视为错误。没有生成object文件。则打开根目录下的Configure。找到-WX删掉即可。

=============如果dll版本运行时提示OPENSSL_Uplink(00640000,08): no OPENSSL_Applink。则从ms文件夹下找到applink.c 加入工程参与编译即可。-------好多年不玩openssl感觉现在玩起来很复杂!

测试代码如下:代码来自https://blog.csdn.net/qianguozheng/article/details/46521781

// 产生RSA密钥
	RSA *rsa = RSA_new();
	BIGNUM* e = BN_new();

	/* 设置随机数长度 */
	BN_set_word(e, 65537);

	/* 生成RSA密钥对 */
	RSA_generate_key_ex(rsa, 2048, e, NULL);

	printf("BIGNUM: %s\n", BN_bn2hex(rsa->n));

	/* 提取私钥 */
	printf("PRIKEY:\n");

	FILE *filename = NULL;
	filename = fopen("privateKey.pem", "wb");
	PEM_write_RSAPrivateKey(filename, rsa, NULL, NULL, 0, NULL, NULL);
	fclose(filename);

	//writeRSA(rsa, NULL);
	/* 提取公钥 */

	unsigned char *n_b = (unsigned char *)calloc(RSA_size(rsa), sizeof(unsigned char));
	unsigned char *e_b = (unsigned char *)calloc(RSA_size(rsa), sizeof(unsigned char));

	int n_size = BN_bn2bin(rsa->n, n_b);
	int b_size = BN_bn2bin(rsa->e, e_b);

	RSA *pubrsa = RSA_new();
	pubrsa->n = BN_bin2bn(n_b, n_size, NULL);
	pubrsa->e = BN_bin2bn(e_b, b_size, NULL);

	printf("PUBKEY: \n");

	FILE *publicKey = NULL;
	publicKey = fopen("publicKey.pem", "wb");
	PEM_write_RSAPublicKey(publicKey, pubrsa);
	fclose(publicKey);

	RSA_free(rsa);
	RSA_free(pubrsa);

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
面向工程应用:市面上的一些密码学课程和密码学的书籍,很多都是从考证出发,讲解算法原理并不面向工程应用,而我们现在缺少的是工程应用相关的知识,本课程从工程应用出发,每种技术都主要讲解其在工程中的使用,并演示工程应用的代码。 从零实现部分算法: 课程中实现了base16编解码 ,XOR对称加解密算法,PKCS7 pading数据填充算法,通过对一些简单算法的实现,从而加深对密码学的理解。理论与实践结合: 课程如果只是讲代码,同学并不能理解接口背后的原理,在项目设计中就会留下隐患,出现错误也不容易排查出问题。如果只讲理论,比如对密码学的一些研究,对于大部分从事工程应用的同学并没有必要,而是理论与实践结合,一切为了工程实践。代码现场打出: 代码不放在ppt而是现场打出,更好的让学员理解代码编写的逻辑,老师现场敲出代码正是展示出了工程项目的思考,每个步骤为什么要这么做,考虑了哪些异常,易学不枯燥: 课程为了确保大部分人开发者都学得会,理解算法原理(才能真正理解算法特性),学会工程应用(接口调用,但不局限接口调用,理解接口背后的机制,并能解决工程中会出现的问题),阅读算法源码但不实现密码算法,,并能将密码学投入到实际工程中,如果是想学习具体的加密算法实现,请关注我后面的课程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值