PHP实现的各类hash算法长度及性能测试实例

本文实例讲述了PHP实现的各类hash算法长度及性能测试。分享给大家供大家参考,具体如下:

Hash结果如下

<?php
$data = "hello world";
foreach (hash_algos() as $v) {
    $r = hash($v, $data, false);
    printf("%-12s %3d %s\n", $v, strlen($r), $r);
}
?>

运行结果:

md2      32 d9cce882ee690a5c1ce70beff3a78c77
md4      32 aa010fbc1d14c795d86ef98c95479d17
md5      32 5eb63bbbe01eeed093cb22bb8f5acdc3
sha1     40 2aae6c35c94fcfb415dbe95f408b9ce91ee846ed
sha224    56 2f05477fc24bb4faefd86517156dafdecec45b8ad3cf2522a563582b
sha256    64 b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
sha384    96 fdbd8e75a67f29f701a4e040385e2e23986303ea10239211af907fcbb83578b3e417cb71ce646efd0819dd8c088de1bd
sha512    128 309ecc489c12d6eb4cc40f50c902f2b4d0ed77ee511a7c7a9bcd3ca86d4cd86f989dd35bc5ff499670da34255b45b0cfd830e81f605dcf7dc5542e93ae9cd76f
ripemd128   32 c52ac4d06245286b33953957be6c6f81
ripemd160   40 98c615784ccb5fe5936fbc0cbe9dfdb408d92f0f
ripemd256   64 0d375cf9d9ee95a3bb15f757c81e93bb0ad963edf69dc4d12264031814608e37
ripemd320   80 0e12fe7d075f8e319e07c106917eddb0135e9a10aefb50a8a07ccb0582ff1fa27b95ed5af57fd5c6
whirlpool  128 8d8309ca6af848095bcabaf9a53b1b6ce7f594c1434fd6e5177e7e5c20e76cd30936d8606e7f36acbef8978fea008e6400a975d51abe6ba4923178c7cf90c802
tiger128,3  32 4c8fbddae0b6f25832af45e7c62811bb
tiger160,3  40 4c8fbddae0b6f25832af45e7c62811bb64ec3e43
tiger192,3  48 4c8fbddae0b6f25832af45e7c62811bb64ec3e43691e9cc3
tiger128,4  32 24465a3f6e4aa92d903ee535476591e9
tiger160,4  40 24465a3f6e4aa92d903ee535476591e937f3a14d
tiger192,4  48 24465a3f6e4aa92d903ee535476591e937f3a14d81c4c7b6
snefru    64 902b49fa8b0828b44d8ac069111899bbfaf51d334485e4b28e90c93f63bb86dd
snefru256   64 902b49fa8b0828b44d8ac069111899bbfaf51d334485e4b28e90c93f63bb86dd
gost     64 1bb6ce69d2e895a78489c87a0712a2f40258d1fae3a4666c23f8f487bef0e22a
gost-crypto  64 c5aa1455afe9f0c440eec3c96ccccb5c8495097572cc0f625278bd0da5ea5e07
adler32    8 1a0b045d
crc32     8 7813f744
crc32b     8 0d4a1185
fnv132     8 548da96f
fnv1a32    8 d58b3fa7
fnv164    16 7dcf62cdb1910e6f
fnv1a64    16 779a65e7023cd2e7
joaat     8 3e4a5a57
haval128,3  32 906c1df7cbe6d318f36ab172f95e89c0
haval160,3  40 6e733b21876e47c2168a122e23d86bdd69e50f95
haval192,3  48 ec67a6a417953fdbf3496502004b6c21b270d5890dedd931
haval224,3  56 766879d9ba1dc9e24a6040908a7ae813a47b08af5c5f3beebcacda48
haval256,3  64 45492c6c8adab277759f4381420799431a037daf6d829b8b5c21104c10f61a92
haval128,4  32 c97d46956b8e3e60acd2bb090c482c5e
haval160,4  40 2cb8b12eb5a2561022010c2a2af8795e602fdef2
haval192,4  48 39a281e4e492533b6dfea0af294149ccac771ab87204c9ec
haval224,4  56 3d64d34aea48f5e649ed6147da5d29d31c762a937e9e21f4da1f3106
haval256,4  64 0359a526d77e271707c44d9b270e68a394f8486a459f0137ad5e1d02e44c5889
haval128,5  32 8332ad9f32e385d9acd421b63ee04cfc
haval160,5  40 d33cf9052d55da9b0f506cb8849097939363e361
haval192,5  48 67c3492878c8fc4819c8589231fcfe69b15b015c1ca48ac5
haval224,5  56 6bedeb6a8676e46413c020c8813c022486ca93353b8a0673fb577ba1
haval256,5  64 f5f6ffcfe39a65ac2c3989430340420341762a6624ebd69b9d08ec1dc4b9f167

性能测试如下:

<?php
define('testtime', 1000000);
$algos = hash_algos();
foreach($algos as $algo) {
  $st = microtime();
  for($i = 0; $i < testtime; $i++) {
    hash($algo, microtime().$i);
  }
  $et = microtime();
  list($ss, $si) = explode(' ', $st);
  list($es, $ei) = explode(' ', $et);
  $time[$algo] = $ei + $es - $si - $ss;
}
asort($time, SORT_NUMERIC);
print_r($time);
?>

运行结果:

Array
(
  [fnv1a32] => 1.4528379546356
  [fnv164] => 1.4598390410767
  [fnv1a64] => 1.4685498960724
  [fnv132] => 1.4695508840027
  [crc32b] => 1.480463955719
  [adler32] => 1.481206043457
  [joaat] => 1.4851269485474
  [crc32] => 1.508364085907
  [md4] => 1.6973789288788
  [md5] => 1.7637529927979
  [sha1] => 1.932477017334
  [tiger128,3] => 1.9683119142761
  [tiger160,3] => 1.9759550503387
  [ripemd128] => 2.0003409449921
  [tiger192,3] => 2.0107291056519
  [tiger128,4] => 2.0609339611664
  [tiger160,4] => 2.0614830404358
  [ripemd256] => 2.1055679496613
  [tiger192,4] => 2.1089930283813
  [ripemd320] => 2.3564790057831
  [ripemd160] => 2.3820580299072
  [sha256] => 2.3944439311981
  [sha224] => 2.4205659084473
  [haval128,3] => 2.5319820201874
  [haval224,3] => 2.5319839861755
  [haval160,3] => 2.5347460784149
  [haval192,3] => 2.5500600071869
  [haval256,3] => 2.580485933548
  [sha384] => 2.6736448852386
  [sha512] => 2.721533025589
  [haval224,4] => 2.9019400155029
  [haval128,4] => 2.9155439011078
  [haval256,4] => 2.9168769813385
  [haval160,4] => 2.9341630749512
  [haval192,4] => 2.9478991126251
  [haval192,5] => 3.1933639251862
  [haval256,5] => 3.1942859609985
  [haval160,5] => 3.1946619862823
  [whirlpool] => 3.1954451004639
  [haval128,5] => 3.2122300287323
  [haval224,5] => 3.295264964798
  [gost] => 4.6756690344391
  [gost-crypto] => 4.6819899302826
  [snefru] => 6.5784390528107
  [snefru256] => 6.6484970919647
  [md2] => 11.291653894501
)

PS:这里再为大家提供2款hash相关在线工具供大家参考使用:

在线散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt

在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php加密方法总结》、《PHP编码与转码操作技巧汇总》、《PHP数学运算技巧总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》

希望本文所述对大家PHP程序设计有所帮助。

(0)

相关推荐

  • PHP的password_hash()使用实例

    一.前言PHP5.5提供了许多新特性及Api函数,其中之一就是Password Hashing API(创建和校验哈希密码).它包含4个函数:password_get_info().password_hash().password_needs_rehash().password_verify().在PHP5.5之前,我们对于密码的加密可能更多的是采用md5或sha1之类的加密方式(没人像CSDN那样存明文吧..),如:echo md5("123456"); //输出: e10adc39

  • PHP 5.5 创建和验证哈希最简单的方法详解

    我们首先讨论password_hash()函数.这将用作创建一个新的密码的哈希值.它包含三个参数:密码.哈希算法.选项.前两项为必须的.你可以根据下面的例子来使用这个函数: 复制代码 代码如下: $password = 'foo';$hash = password_hash($password,PASSWORD_BCRYPT);//$2y$10$uOegXJ09qznQsKvPfxr61uWjpJBxVDH2KGJQVnodzjnglhs2WTwHu 你将注意到我们并没有给这个哈希加任何选项.现

  • PHP Hash算法:Times33算法代码实例

    最近看书,里面提到了一些Hash算法.比较有印象的是Times33,当时理解不是很透测,今天写了段程序来验证了一下. 先上代码: 复制代码 代码如下: <?php /**  * CRC32 Hash function  * @param $str  * @return int  */ function hash32($str) {     return crc32($str) >> 16 & 0x7FFFFFFF; } /**  * Times33 Hash function  

  • PHP中用hash实现的数组

    PHP中使用最多的非Array莫属了,那Array是如何实现的?在PHP内部Array通过一个hashtable来实现,其中使用链接法解决hash冲突的问题,这样最坏情况下,查找Array元素的复杂度为O(N),最好则为1. 而其计算字符串hash值的方法如下,将源码摘出来以供查备: 复制代码 代码如下: static inline ulong zend_inline_hash_func(const char *arKey, uint nKeyLength) { register ulong h

  • PHP中对各种加密算法、Hash算法的速度测试对比代码

    PHP 的Hash算法是比较常用的,现在的MD5有时候不太安全,就得用到Hash_algos()中的其它算法,下面进行了一个性能的比较. php代码: define('testtime', 50000); $algos = hash_algos(); foreach($algos as $algo) { $st = microtime(); for($i = 0; $i < testtime; $i++) { hash($algo, microtime().$i); } $et = microt

  • 理解php Hash函数,增强密码安全

    1.声明 密码学是一个复杂的话题,我也不是这方面的专家.许多高校和研究机构在这方面都有长期的研究.在这篇文章里,我希望尽量使用简单易懂的方式向你展示一种安全存储Web程序密码的方法. 2."Hash"是做什么的? "Hash将一段数据(小数据或大数据)转换成一段相对短小的数据,如字符串或整数." 这是依靠单向hash函数来完成的.所谓单向是指很难(或者是实际上不可能)将其反转回来.一个常见的hash函数的例子是md5(),它流行于各种计算机语言和系统. 复制代码 代

  • php 分库分表hash算法

    复制代码 代码如下: //分库分表算法 function calc_hash_db($u, $s = 4) { $h = sprintf("%u", crc32($u)); $h1 = intval(fmod($h, $s)); return $h1; } for($i=1;$i<100;$i++) { echo calc_hash_db($i); echo "<br>"; } function calc_hash_tbl($u, $n = 256

  • php的hash算法介绍

    Hash Table是PHP的核心,这话一点都不过分. PHP的数组,关联数组,对象属性,函数表,符号表,等等都是用HashTable来做为容器的. PHP的HashTable采用的拉链法来解决冲突, 这个自不用多说, 我今天主要关注的就是PHP的Hash算法, 和这个算法本身透露出来的一些思想. PHP的Hash采用的是目前最为普遍的DJBX33A (Daniel J. Bernstein, Times 33 with Addition), 这个算法被广泛运用与多个软件项目,Apache, P

  • php-perl哈希算法实现(times33哈希算法)

    复制代码 代码如下: APR_DECLARE_NONSTD(unsigned int) apr_hashfunc_default(const char *char_key,                                                      apr_ssize_t *klen){    unsigned int hash = 0;    const unsigned char *key = (const unsigned char *)char_key;  

  • 一致性哈希算法以及其PHP实现详细解析

    在做服务器负载均衡时候可供选择的负载均衡的算法有很多,包括:  轮循算法(Round Robin).哈希算法(HASH).最少连接算法(Least Connection).响应速度算法(Response Time).加权法(Weighted )等.其中哈希算法是最为常用的算法. 典型的应用场景是: 有N台服务器提供缓存服务,需要对服务器进行负载均衡,将请求平均分发到每台服务器上,每台机器负责1/N的服务. 常用的算法是对hash结果取余数 (hash() mod N):对机器编号从0到N-1,按

  • PHP随机生成唯一HASH值自定义函数

    网上有很多种方法获取随机唯一的HASH值,但是大同小异: 1.先获取随机的唯一字符串 2.进行MD5或者sha1算HASH值 一个项目要用到hash值,就去网上找了找,却发现PHP有一个函数能直接生成唯一字符串--uniqid(),通过使用这个函数,再加上自己生成的随机数(防止被破解),更具有唯一性且不易被猜解.主要考虑问题如下: 1.随机的效率与随机性:rand和mt_rand函数的选择,首选mt_rand,效率高,随机性好: 2.随机次数:选择5次,本来unniqid就是唯一的,加上随机的可

随机推荐