#include <openssl/rsa.h>
#include <openssl/pem.h>
#include <openssl/err.h>
#include <openssl/sha.h>
#include <openssl/crypto.h>
void print_Hash(unsigned char *md, int len)
{
int i = 0;
printf("===============hash: ");
for (i = 0; i < len; i++)
{
printf("%02x", md[i]);
}
printf("\n\n\n");
}
EVP_PKEY *PEM_read_PublicKey(FILE *fp)
{
BIO *b;
EVP_PKEY *ret;
if ((b=BIO_new(BIO_s_file())) == NULL)
{
PEMerr(PEM_F_PEM_READ_PRIVATEKEY,ERR_R_BUF_LIB);
return(0);
}
BIO_set_fp(b,fp,BIO_NOCLOSE);
ret=PEM_read_bio_PUBKEY(b, NULL, NULL, NULL);
BIO_free(b);
return(ret);
}
/*读取私钥*/
EVP_PKEY* Read_PrivateKey(char* p_KeyPath)
{
FILE *fp = NULL;
char szKeyPath[1024];
EVP_PKEY *priRsa = NULL, *pubRsa = NULL, *pOut = NULL;
/* 打开密钥文件 */
if(NULL == (fp = fopen(p_KeyPath, "r")))
{
Error_Printf( "fopen[%s] failed \n", p_KeyPath);
return NULL;
}
/* 获取私密钥 */
priRsa = PEM_read_PrivateKey(fp, NULL, NULL,NULL);
if(NULL == priRsa)
{
ERR_print_errors_fp(stdout);
Error_Printf("PEM_read_PrivateKey failed !!!\n");
fclose(fp);
return NULL;
}
fclose(fp);
c语言实现签名和签名验证
最新推荐文章于 2024-07-15 18:05:53 发布
本文详细介绍了如何使用C语言实现数字签名的生成及验证过程,涉及公钥加密算法和哈希函数的应用,旨在确保数据的完整性和来源可靠性。
摘要由CSDN通过智能技术生成