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);