MD5、sha1、sha256分别输出多少位?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MD5、sha1、sha256分别输出多少位?相关的知识,希望对你有一定的参考价值。
_
MD5 SHA1 SHA256 这3种本质都是摘要函数,它们的长度 MD5 是 128 位,SHA1 是 160 位 ,SHA256 是 256 位。
MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。
对于长度小于2^64位的消息,SHA1会产生一个160位的消息摘要。当接收到消息的时候,这个消息摘要可以用来验证数据的完整性。
哈希值用作表示大量数据的固定大小的唯一值。数据的少量更改会在哈希值中产生不可预知的大量更改。SHA256 算法的哈希值大小为 256 位。
扩展资料
MD5算法的应用:
1、一致性验证
MD5可以为任何文件(不管其大小、格式、数量)产生一个同样独一无二的“数字指纹”,如果任何人对文件做了任何改动,其MD5值也就是对应的“数字指纹”都会发生变化。
利用MD5算法来进行文件校验的方案被大量应用到软件下载站、论坛数据库、系统文件安全等方面。
2、数字签名
MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹),以防止被“篡改”。
举个例子,你将一段话写在一个叫 readme.txt文件中,并对这个readme.txt产生一个MD5的值并记录在案,然后你可以传播这个文件给别人,别人如果修改了文件中的任何内容,你对这个文件重新计算MD5时就会发现(两个MD5值不相同)。
如果再有一个第三方的认证机构,用MD5还可以防止文件作者的“抵赖”,这就是所谓的数字签名应用。
3、安全访问认证
MD5还广泛用于操作系统的登陆认证上,如Unix、各类BSD系统登录密码、数字签名等诸多方面。如在Unix系统中用户的密码是以MD5(或其它类似的算法)经Hash运算后存储在文件系统中。
参考资料:百度百科-SHA256
参考资料:百度百科-SHA1
参考资料:百度百科-MD5
MD5输出128bit、SHA1输出160bit、SHA256输出256bit
MD5释义:即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5作用:让大容量信息在用数字签名软件签署私人密钥前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。除了MD5以外,其中比较有名的还有sha-1、RIPEMD以及Haval等。
sha1释义:安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准 (Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signature Algorithm DSA)。对于长度小于2^64位的消息,SHA1会产生一个160位的消息摘要。当接收到消息的时候,这个消息摘要可以用来验证数据的完整性。在传输的过程中,数据很可能会发生变化,那么这时候就会产生不同的消息摘要。
sha1特点:不可以从消息摘要中复原信息;两个不同的消息不会产生同样的消息摘要,(但会有1x10 ^ 48分之一的机率出现相同的消息摘要,一般使用时忽略)。
sha256释义:哈希值用作表示大量数据的固定大小的唯一值。数据的少量更改会在哈希值中产生不可预知的大量更改。SHA256算法的哈希值大小为 256 位。
sha256特点:作表示大量数据的固定大小。
PHP 之sha256 sha512封装
/* PHP sha256 sha512目前(PHP 7.1)没有内置的函数来计算,sha1() sha1_file() md5() md5_file()分别可以用来计算字符串和文件的sha1散列值和md5散列值,当前最新版本PHP 7.1 sha256() sha256_file() sha512() sha512_file()这样的函数也没有。SHA-2是SHA-224、SHA-256、SHA-384,和SHA-512的合称。 PHP 计算sha256 sha512可以使用hash()函数实现,计算文件的sha256 sha512则可以使用hash_file()实现。 hash($algo , $data, $rawOutput); hash_file($algo , $filepath, $rawOutput); 其中$algo是算法,可以是sha256, sha512等值,支持的算法可以使用hash_algos()查看,该函数返回所有支持的算法。 $data是需要计算hash值的字符串,$filepath是需要计算hash值的文件名,可以是相对路径也可以是绝对路径。 $rawOutput是一个可选的布尔值参数,如果为true,则返回二进制数据,如果为false则返回字符串,默认值为false. 我们可以封装自定义函数来实现PHP 计算sha256 sha512以及其他类型的hash值。 以下代码实现PHP sha256() sha256_file() sha512() sha512_file() */ /* * 以下代码实现PHP sha256() sha256_file() sha512() sha512_file() PHP 5.1.2+完美兼容 * @param string $data 要计算散列值的字符串 * @param boolean $rawOutput 为true时返回原始二进制数据,否则返回字符串 * @param string file 要计算散列值的文件名,可以是单独的文件名,也可以包含路径,绝对路径相对路径都可以 * @return boolean | string 参数无效或者文件不存在或者文件不可读时返回false,计算成功则返回对应的散列值 * @notes 使用示例 sha256(‘www.wuxiancheng.cn‘) sha512(‘www.wuxiancheng.cn‘) sha256_file(‘index.php‘) sha512_file(‘index.php‘) */ /* PHP sha256() */ function sha256($data, $rawOutput = false) { if (!is_scalar($data)) { return false; } $data = (string)$data; $rawOutput = !!$rawOutput; return hash(‘sha256‘, $data, $rawOutput); } /* PHP sha256_file() */ function sha256_file($file, $rawOutput = false) { if (!is_scalar($file)) { return false; } $file = (string)$file; if (!is_file($file) || !is_readable($file)) { return false; } $rawOutput = !!$rawOutput; return hash_file(‘sha256‘, $file, $rawOutput); } /* PHP sha512() */ function sha512($data, $rawOutput = false) { if (!is_scalar($data)) { return false; } $data = (string)$data; $rawOutput = !!$rawOutput; return hash(‘sha512‘, $data, $rawOutput); } /* PHP sha512_file()*/ function sha512_file($file, $rawOutput = false) { if (!is_scalar($file)) { return false; } $file = (string)$file; if (!is_file($file) || !is_readable($file)) { return false; } $rawOutput = !!$rawOutput; return hash_file(‘sha512‘, $file, $rawOutput); }
以上是关于MD5、sha1、sha256分别输出多少位?的主要内容,如果未能解决你的问题,请参考以下文章