php专区

 首页 > php专区 > PHP应用 > 常用功能 > openssl使用DSA算法生成签名实例详解 - php高级应用

openssl使用DSA算法生成签名实例详解 - php高级应用

分享到:
【字体:
导读:
          命令:openssl dgst -dss1 -sign C.pri -out signature.bin s.txt解释:C.pri是DSA算法生成的私钥文件,s.txt是制作签名的原文,signature.bin是生成的签名文件php中可以使用下面的方法察看签......

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

命令:openssl> dgst -dss1 -sign C.pri -out signature.bin s.txt

解释:C.pri是DSA算法生成的私钥文件,s.txt是制作签名的原文,signature.bin是生成的签名文件

php中可以使用下面的方法察看签名内容,代码如下:

  1. echo bin2hex(file_get_contents('signature.bin'));//开源代码phpfensi.com 
  2. ?>  

参考内容:消息摘要算法

支持的算法包括: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

分享到:
php open_basedir安全与使用详解 - php高...
php open_basedir安全与使用详解 open_basedir的作用就是指定目录位置了,意思是将PHP 所能打开的文件限制在指定的目录树,包括文件本身了,并且不受是不是安全模式的影响. 如下是php.ini中的原文说明以及默认配置: ; open_basedir, if set, limits all file operations to the ...
php预防XSS攻击的一些方法整理 - php高级...
php预防XSS攻击的一些方法整理 现在有很多php开发框架都提供关于防XSS攻击的过滤方法,下面和大家分享一个预防XSS攻击和ajax跨域攻击的函数,摘自某开发框架,相比于仅仅使用内置函数应该还是够强了的吧. 对网站发动XSS攻击的方式有很多种,仅仅使用php的一些内置过滤函数是对付不了的,即使你将f...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……