一种OPENSSL_Uplink(100F2010,05): no OPENSSL_Applink解决方法

本文解决了一个在使用Openssl库读取RSA私钥时遇到的问题,通过从直接文件读取改为使用BIO方式成功解决了OPENSSL_Uplink错误。

   最近项目中使用Openssl库时,程序编译没有错误,但是执行时出现OPENSSL_Uplink(100F2010,05): no OPENSSL_Applink错误,在网上找了好多原因,大部分是说DLL库调用方式不正确,应该修改为与Openssl库相同的编译方式也就是/Md方式,但是都不能解决问题,我的代码是从一个pem文件中读取RSA私钥,出错的代码如下:

   FILE* fp = fopen (keyFileName, "r");
 if ( fp == 0 )
 {
  perror(keyFileName);
  return (-1);
 }

 m_PrivateKey = PEM_read_PrivateKey(fp, 0, 0, 0);
 fclose(fp);
 if ( m_PrivateKey == 0 )
 {
  cerr << "Error reading RSA key in file " <<keyFileName<< endl;
  return (-1);
 }

 

  最后把上述读取私钥的代码修改为通过BIO方式读取,上述问题不再出现,代码如下:

  BIO* in=NULL;
 //生成IO对象
 in = BIO_new(BIO_s_file());
 //将Key文件读入IO
 BIO_read_filename(in,keyFileName);
 if (in == NULL)
 {
  perror(keyFileName);
  return -1;
 }
 //将IO中数据以PEM格式读入EVP_PKEY结构中
 m_PrivateKey = PEM_read_bio_PrivateKey(in, NULL, NULL, NULL);
 if (in != NULL)
  BIO_free (in);

 if ( m_PrivateKey == NULL )
 {
  cerr << "读取Key文件失败! " << keyFileName << endl;
  return -1;
 }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值