指点成金-最美分享吧

登录

MD5、sha1、sha256分别输出多少位?

佚名 举报

篇首语:本文由小编为大家整理,主要介绍了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



参考技术A

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分别输出多少位?的主要内容,如果未能解决你的问题,请参考以下文章