openssl rsa公钥验签名

在C++环境中,使用OpenSSL库进行RSA公钥签名验证时遇到问题。由于只拥有公钥字符串(Base64编码),在尝试从内存加载公钥时遇到错误‘PEM_read_bio:no start line’。此错误表明API可能需要证书而非单独的公钥。目前不清楚如何仅用公钥字符串生成证书,寻求解决方案。
摘要由CSDN通过智能技术生成

场景:

只有公钥字符串(base64编码),需验证签名。

环境:

c++ + openssl

step1 从内存读取公钥

static RSA* GetPublicKeyRSA(string strPublicKey)
	{
		int nPublicKeyLen = strPublicKey.size();      //strPublicKey为base64编码的公钥字符串
		for(int i = 64; i < nPublicKeyLen; i+=64)
		{
			if(strPublicKey[i] != '\n')
			{
				strPublicKey.insert(i, "\n");
			}
			i++;
		}
		strPublicKey.insert(0, "-----BEGIN PUBLIC KEY-----\n");
		strPublicKey.append("\n-----END PUBLIC KEY-----\n");

		BIO *bio = NULL; 
		RSA *rsa = NULL; 
		char *chPublicKey = const_cast<char *>(strPublicKey.c_str());
		if ((bio = BIO_new_mem_buf(chPublicKey, -1)) == NULL)       //从字符串读取RSA公钥
		{     
			cout<<"BIO_new_mem_buf failed!"<<endl;      
		}       
		rsa = PEM_read_bio_RSA_PUBKEY(bio, NULL, NULL, NULL);   //从bio结构中得到rsa结构
		if (NULL &#
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值