您好,欢迎访问一九零五行业门户网

openssl使用DSA算法生成签名实例详解_PHP教程

文章给大家介绍基于openssl使用dsa算法生成签名实例,生成签名方法很简单,我们需要懂得中间的原理就比较复杂了,大家一起来看看吧。
命令:
openssl> dgst -dss1 -sign c.pri -out signature.bin s.txt
解释
c.pri是dsa算法生成的私钥文件
s.txt是制作签名的原文
signature.bin是生成的签名文件
php中可以使用下面的方法察看签名内容
 代码如下 复制代码
参考内容
消息摘要算法
支持的算法包括:md2, md4, md5, mdc2, sha1(有时候叫做dss1), ripemd-160。sha1和ripemd-160产生160位哈西值,其他的产生128位。除非出于兼容性考虑,否则推荐使用sha1或者ripemd-160。
除了ripemd-160需要用rmd160命令外,其他的算法都可用dgst命令来执行。
openssl对于sha1的处理有点奇怪,有时候必须把它称作dss1来引用。
消息摘要算法除了可计算哈西值,还可用于签名和验证签名。签名的时候,对于dsa生成的私匙必须要和dss1(即sha1)搭配。而对于rsa生成的私匙,任何消息摘要算法都可使用。
# 消息摘要算法应用例子
# 用sha1算法计算文件file.txt的哈西值,输出到stdout
$ openssl dgst -sha1 file.txt
# 用sha1算法计算文件file.txt的哈西值,输出到文件digest.txt
$ openssl sha1 -out digest.txt file.txt
# 用dss1(sha1)算法为文件file.txt签名,输出到文件dsasign.bin
# 签名的private key必须为dsa算法产生的,保存在文件dsakey.pem中
$ openssl dgst -dss1 -sign dsakey.pem -out dsasign.bin file.txt
# 用dss1算法验证file.txt的数字签名dsasign.bin,
# 验证的private key为dsa算法产生的文件dsakey.pem
$ openssl dgst -dss1 -prverify dsakey.pem -signature dsasign.bin file.txt
# 用sha1算法为文件file.txt签名,输出到文件rsasign.bin
# 签名的private key为rsa算法产生的文件rsaprivate.pem
$ openssl sha1 -sign rsaprivate.pem -out rsasign.bin file.txt
# 用sha1算法验证file.txt的数字签名rsasign.bin,
# 验证的public key为rsa算法生成的rsapublic.pem
$ openssl sha1 -verify rsapublic.pem -signature rsasign.bin file.txt
http://www.bkjia.com/phpjc/632818.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/632818.htmltecharticle文章给大家介绍基于openssl使用dsa算法生成签名实例,生成签名方法很简单,我们需要懂得中间的原理就比较复杂了,大家一起来看看吧。...
其它类似信息

推荐信息