尝试使用Lockbox 3在Delphi中加载RSA公钥我遇到此错误:“(错误)公钥文件损坏,空或错误的类型。” 我使用以下命令通过OpenSSL生成了一对公钥和私钥:
openssl genrsa -out private.pem 2048 //generate private key
openssl rsa -pubout -in private.pem -out public.pem //generate public key
然后在Delphi中我使用以下代码加载libeay32.dll:
sig: TOpenSSL_Signatory;
...
Sig.Clear;
Sig.isLoaded := True;
if Sig.isLoaded then ShowMessage('The OpenSSL library libeay32.dll was loaded successfully.');
总是加载成功的。 然后我使用下面的代码加载公钥(即public.pem):
f:=TFileStream.Create('c:\keys\public.pem', fmOpenRead);
sig.LoadKeysFromStream(f, [partPublic]);
f.Free;
以上代码导致以下错误: “(错误)公钥文件损坏,为空或类型错误。”
如何解决这个问题并将OpenSSL生成的公钥成功加载到Delphi?
public.pem如下所示:
-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAz98tqhhArIOoTtO3HFDW
TcQz4EcSBIc3YejV9GPQq+gMdqO5VsmQhOfHyWAMwOVJ49w/fGib+zyIPmocwCqE
jnQ5UjpNhkO5JIDmlf5NZGI2JcuORg+4Anqgo0D4YGCY04w7Sk8dArLHK+PThPwC
uM2XqyRCpcyTsWRKcH5/G6k6OBBhj5kIeNOy+ZCLeADhNUNiEBXdHQWoMbC+x8Fk
E73KzoOg61BQ7HBMJmfK2p8Shi/wEqD1DPJK3IKkTS+KAB8LvLXdUTDHg1O6FbDn
FfSQWYXzV5MWZR7M3POyX6rjoGRFK+v3mG08S5qEPj/l/PBgNL6wI/aBNkFsYxgf
7QIDAQAB
-----END PUBLIC KEY-----
答案 0 :(得分:1)
方法TOpenSSL_Signatory.LoadKeysFromStream()
期待密钥以...结尾
-----END RSA PUBLIC KEY-----
此方法希望密钥为PEM(SSLeay)格式。 SSLeay PEM的base64内容标记为-----BEGIN/END RSA PUBLIC/PRIVATE KEY-----。
要生成传统PEM格式的密钥,请参阅...
您无法通过重命名页眉/页脚来更改格式。实际上,您必须通过将正确的选项传递给OpenSSL来生成SSLeay PEM。