使用openSSL在VS2017进行RSA的加密解密

使用OpenSSL在VS2017进行RSA的加密解密

RSA介绍

  • 公钥密码体制的介绍内容在网页上有很多,为避免重复,此处不再介绍RSA背景内容。

使用OpenSSL进行RSA加密、解密操作

  • openssl的背景知识百度上已经有很多了,此处不再介绍OpenSSL的背景内容。

在装好了OpenSSL之后,在VS2017中可以开始我们的工程。

关于如何开启工程、将OPENSSL库进行链接,这篇文章中进行了较为详细的讲解,链接如下:https://blog.csdn.net/wene_zheng/article/details/53101260

这里对openSSL库中与RSA相关的结构体、接口函数做一个简单的介绍:

所有的函数声明在openssl\include\openssl\rsa.h中,首先我们面临的是结构体RSA的内容。

所有的结构体是在ossl_typ.h中定义的,我们打开这个文件可以看到:

typedef struct rsa_st RSA;

接下来google到了rsa_st的结构,在这里,推荐一个网址,这个网站可以搜索到结构体的声明详细内容

https://docs.huihoo.com/doxygen/openssl/1.0.1c/annotated.html

这个结构如下:

struct {
   
    //BIGNUM 是一个结构体,可以理解为一个“大数”,他的定义为bignum_st,一个过大的数在内存中是无法存储的
    //需要使用结构体进行大数的存储
    BIGNUM *n;              // 模n=pq
    BIGNUM *e;              // 公钥
    BIGNUM *d;              // 私钥
    BIGNUM *p;              // 秘密大素数P
    BIGNUM *q;              // 秘密大素数q
    BIGNUM *dmp1;           // d mod (p-1)
    BIGNUM *dmq1;           // d mod (q-1)
    BIGNUM *iqmp;           // q^-1 mod p
    // ...
    //当然内容远不止此,还包括pad、version、flag等内容。以上是RSA的基本内容
} rsa_st;

和RSA结构相关的有许多操作函数,包含在rsa.h中,这些函数的描述可以在Openssl的官网上找到,这个网址为

https://www.openssl.org/docs/manpages.html

//初始化一个RSA结构,这里用的是C语言,使用前必须要初始化
RSA * RSA_new(void);
//释放一个RSA结构
void RSA_free(RSA *rsa);
//RSA私钥产生函数,类似的产生函数还有RSA_generate_key_ex等,可以看上面网站的描述
//产生一个模为num位的密钥对,e是公钥,产生的密钥对会放进返回值RSA结构体中
RSA *RSA_generate_key(int num, unsigned long e,void (*callback)(int,int,void *), void *cb_arg);
//判断位数函数, 返回RSA模的位数
int RSA_size(const RSA *rsa);
//测试p、q是否为素数
int RSA_check_key(RSA *rsa);
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值