Security | RSA2048私钥存在小于256byte(比如255byte)

最近搞TEE里面Crypto模块,遇到RSA2048 Private key(d因子)只有255byte

而在解密的时候我直接使用长度为256byte,导致解密失败(原因是末尾补零出现公私钥不匹配)

解决方法要么使用255byte,要么高位补零(比256小都需要高位补零)

TEE_GetObjectBufferAttribute(key, attributeID, d, &dL);
uint32_t cnt = 256 - dL;
if (cnt > 0) {
	char tmp[512] = { 0 };
	memcpy(tmp + cnt, d, dL);
	memset(d, 0x00, 256);
	memcpy(d, tmp, dL + cnt);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值