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