c语言实现签名和签名验证

#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);
  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
以下是RSA数字签名验证C语言代码示例: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <openssl/rsa.h> #include <openssl/pem.h> #define KEY_LENGTH 2048 #define PUB_EXP 3 #define PRI_EXP 65537 #define BLOCK_SIZE 256 int main() { RSA *rsa = RSA_new(); BIGNUM *bne = BN_new(); BIO *bio = NULL; int ret = -1; // 生成RSA密钥对 BN_set_word(bne, PUB_EXP); rsa = RSA_new(); ret = RSA_generate_key_ex(rsa, KEY_LENGTH, bne, NULL); if (ret != 1) { printf("Failed to generate RSA key pair!\n"); return -1; } // 使用私钥进行数字签名 unsigned char msg[] = "Hello, world!"; unsigned char signature[BLOCK_SIZE] = {0}; unsigned int sig_len = 0; bio = BIO_new(BIO_s_mem()); PEM_write_bio_RSAPrivateKey(bio, rsa, NULL, NULL, 0, NULL, NULL); sig_len = RSA_private_encrypt(sizeof(msg) - 1, msg, signature, rsa, RSA_PKCS1_PADDING); BIO_free_all(bio); // 使用公钥进行签名验证 bio = BIO_new(BIO_s_mem()); PEM_write_bio_RSA_PUBKEY(bio, rsa); RSA *rsa_pubkey = RSA_new(); PEM_read_bio_RSA_PUBKEY(bio, &rsa_pubkey, NULL, NULL); ret = RSA_public_decrypt(sig_len, signature, msg, rsa_pubkey, RSA_PKCS1_PADDING); BIO_free_all(bio); if (ret != sizeof(msg) - 1 || memcmp(msg, "Hello, world!", sizeof(msg) - 1) != 0) { printf("Signature verification failed!\n"); return -1; } else { printf("Signature verification succeeded!\n"); } RSA_free(rsa); RSA_free(rsa_pubkey); BN_free(bne); return 0; } ``` 该示例代码使用OpenSSL库实现RSA数字签名验证。首先,它生成一个2048位的RSA密钥对。然后,使用私钥对消息进行签名,使用公钥对签名进行验证。如果签名验证成功,则输出“Signature verification succeeded!”,否则输出“Signature verification failed!”。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿木小呆呆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值