xiaogary2014
2015-01-15 15:05openssl 的RSAD的调用
function RSA_decrypt(var tmp:PAnsiChar):PAnsiChar ; stdcall;
var
rsa: PRSA;
key: PBIO;
pkey: PEVP_PKEY;
keysize :Integer;
ret,P_en:PChar;
begin
key := BIO_new(BIO_s_file());
BIO_read_filename(key,'c:\publickey.txt');
pkey := PEM_read_bio_PUBKEY(key,pkey,nil,nil);
rsa := EVP_PKEY_get1_RSA(pkey);
keysize := RSA_size(rsa);
P_en:=allocmem(keysize+1);
FillMemory(P_en,SizeOf(P_en),0);
//RSA_public_decrypt(keysize,tmp,ret,rsa,RSA_PKCS1_PADDING);
RSA_public_encrypt(keysize,tmp,P_en,rsa,RSA_PKCS1_PADDING);
Result:=P_en;
// RSA_free(rsa);
end;
调用有问题,一直返回空,不知道哪里的问题。。解密有内容后直接就崩溃。
- 点赞
- 回答
- 收藏
- 复制链接分享
2条回答
为你推荐
- 从PEM文件加载(生成的OpenSSL)DSA私钥
- openssl
- 1个回答
- 使用golang解密使用php openssl_encrypt加密的文件
- openssl
- encryption
- php
- 1个回答
- crypto / sha1不匹配openssl命令
- openssl
- sha
- 1个回答
- 在CentOS上用OpenSSL重新编译PHP
- centos7
- openssl
- php
- 2个回答
- 在Ubuntu中使用PHP openssl
- openssl
- ubuntu
- php
- 1个回答
换一换