Open SSL 常用函数——签名与验证

 

OpenSSL中的验证是先对原始数据计算摘要, 再对摘要进行私钥加密. 验证的过程是对原始消息计算摘要,解密验证值, 和摘要对比是否一致.如果一致, 说明验证有效:否则,则认为原文或验证值已经被篡改.

         函数介绍:

因为要先对原始数据计算摘要, 所以在计算摘要时用的函数是计算摘要的函数一样. 最后在结束函数中进行验证或验证. 为了方便描述, OpenSSL对计算摘要函数进行了宏定义封装.下边是函数定义:

1、  签名初始化函数

#define EVP_SignInit_ex(a, b, c)                 EVP_DigestInit_ex(a, b, c)

Int EVP_DigestInit_ex(EVP_MD_CTX *ctx, const EVP_MD *type, ENGINE *imp1);

2、  签名更新函数

#define EVP_SignUpdate(a, b, c)                EVP_DigestUpdate(a, b, c)

Int EVP_DigestUpdate(EVP_MD_CTX *ctx, const *d, size_t cnt);

3、  签名结束函数

Int EVP_SignFinal(EVP_MD_CTX *ctx, unsigned char *md, unsigned int *s, EVP_PKey pkey);

功能:计算签名结束, 输出签名值。

参数说明:

Ctx[IN]上下文变量

Md[OUT] 签名结果输出值的指针  s[OUT] 签名的长度

Pkey[IN] 签名的私钥。(*后面有私钥的计算过程)

4、  验证初始化函数 (* 跟签名调用同一个函数)

#define EVP_VerifyInit_ex(a, b, c)              EVP_DigestInit_ex(a, b, c)

Int EVP_DigestInit_ex(EVP_MD_CTX *ctx, const EVP_MD *type, ENGINE *imp1);

5、  验证更新函数(* 跟签名调用同一个函数)

#define EVP_VerifyUpdate(a, b, c)             EVP_DigestUpdate(a, b, c)

Int EVP_DigestUpdate(EVP_MD_CTX *ctx, const *d, size_t cnt);

6、  验证结束函数

Int EVP_VerifyFinal(EVP_MD_CTX *ctx, const unsigned char *sigbuf, unsigned int siglen, EVP_PKey pkey);

功能:计算验证结束, 输出验证值。

参数说明:

Ctx[IN]上下文变量

sigbuf[IN] 签名值  siglen[IN] 签名的长度

Pkey[IN] 验证签名的公钥。

计算私钥过程: 直接写代码出来(*下面的代码如果按百分算的话,最多只能得三十分, 所以不要照搬, 我这么写只是想把过程说得简单清楚点)

RSA rsa = RSA_generate_key(1024, RSA_F4, NULL, NULL);//产生一个1024位的RSA密钥

EVP_PKEY *evpKey = EVP_PKEY_new(); //新建一个EVP_PKEY变量

EVP_PKEY_set1_RSA(evpKey, rsa);  //保存RSA结构体到EVP_PKEY结构体

//完成任务后面就可以用evpKey来签名了。

 

注:上面资源大多源自《精通PKI网络安全论证技术与编程实现》一书。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值