使用Perl中的Crypt :: OpenSSL :: RSA签名数据
发布时间:2020-12-15 23:36:03 所属栏目:大数据 来源:网络整理
导读:我正在尝试使用Perl中的Crypt :: OpenSSL :: RSA来签署我的数据.这是我的代码 use Crypt::OpenSSL::RSA;open $privfh,':encoding(UTF-8)','private_key';$rsa = Crypt::OpenSSL::RSA-generate_key(1024); $key_string=$rsa-get_private_key_string();print $
我正在尝试使用Perl中的Crypt :: OpenSSL :: RSA来签署我的数据.这是我的代码
use Crypt::OpenSSL::RSA; open $privfh,'>:encoding(UTF-8)','private_key'; $rsa = Crypt::OpenSSL::RSA->generate_key(1024); $key_string=$rsa->get_private_key_string(); print $privfh $key_string; $rsa_priv = Crypt::OpenSSL::RSA->new_private_key($key_string); $rsa_pub = $rsa->get_public_key_string(); $plaintext="hello"; $signature = $rsa_priv->sign($plaintext); print "Signed correctlyn" if ($rsa->verify($plaintext,$signature)); 这个程序运行正常,我能够正确签名数据.但问题是我必须签署大量数据,所以我将key_string写入文件,以便我可以一次又一次地使用它,但问题是当我尝试使用以下代码再次使用它时 use Crypt::OpenSSL::RSA; open FILE,'<','private_key'; { local $/; $keystring=<FILE>; } print "$keystringn"; $rsa_priv = Crypt::OpenSSL::RSA->new_private_key($key_string); 它抛出错误而不生成$rsa_priv.该程序给出的错误是 解决方法
您正在将文件读入变量$keystring,但使用变量$key_string初始化私钥.将$keystring更改为$key_string.
Perl提供严格使用;避免这些问题.此外,如果您使用use warnings;,perl还会警告您访问单元化变量. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |