Hash结果如下

  1. <?php
  2. $data = "hello world";
  3.  
  4. foreach (hash_algos() as $v) {
  5. $r = hash($v, $data, false);
  6. printf("%-12s %3d %s\n", $v, strlen($r), $r);
  7. }
  8. ?>
  9. md2 32 d9cce882ee690a5c1ce70beff3a78c77
  10. md4 32 aa010fbc1d14c795d86ef98c95479d17
  11. md5 32 5eb63bbbe01eeed093cb22bb8f5acdc3
  12. sha1 40 2aae6c35c94fcfb415dbe95f408b9ce91ee846ed
  13. sha224 56 2f05477fc24bb4faefd86517156dafdecec45b8ad3cf2522a563582b
  14. sha256 64 b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
  15. sha384 96 fdbd8e75a67f29f701a4e040385e2e23986303ea10239211af907fcbb83578b3e417cb71ce646efd0819dd8c088de1bd
  16. sha512 128 309ecc489c12d6eb4cc40f50c902f2b4d0ed77ee511a7c7a9bcd3ca86d4cd86f989dd35bc5ff499670da34255b45b0cfd830e81f605dcf7dc5542e93ae9cd76f
  17. ripemd128 32 c52ac4d06245286b33953957be6c6f81
  18. ripemd160 40 98c615784ccb5fe5936fbc0cbe9dfdb408d92f0f
  19. ripemd256 64 0d375cf9d9ee95a3bb15f757c81e93bb0ad963edf69dc4d12264031814608e37
  20. ripemd320 80 0e12fe7d075f8e319e07c106917eddb0135e9a10aefb50a8a07ccb0582ff1fa27b95ed5af57fd5c6
  21. whirlpool 128 8d8309ca6af848095bcabaf9a53b1b6ce7f594c1434fd6e5177e7e5c20e76cd30936d8606e7f36acbef8978fea008e6400a975d51abe6ba4923178c7cf90c802
  22. tiger128,3 32 4c8fbddae0b6f25832af45e7c62811bb
  23. tiger160,3 40 4c8fbddae0b6f25832af45e7c62811bb64ec3e43
  24. tiger192,3 48 4c8fbddae0b6f25832af45e7c62811bb64ec3e43691e9cc3
  25. tiger128,4 32 24465a3f6e4aa92d903ee535476591e9
  26. tiger160,4 40 24465a3f6e4aa92d903ee535476591e937f3a14d
  27. tiger192,4 48 24465a3f6e4aa92d903ee535476591e937f3a14d81c4c7b6
  28. snefru 64 902b49fa8b0828b44d8ac069111899bbfaf51d334485e4b28e90c93f63bb86dd
  29. snefru256 64 902b49fa8b0828b44d8ac069111899bbfaf51d334485e4b28e90c93f63bb86dd
  30. gost 64 1bb6ce69d2e895a78489c87a0712a2f40258d1fae3a4666c23f8f487bef0e22a
  31. gost-crypto 64 c5aa1455afe9f0c440eec3c96ccccb5c8495097572cc0f625278bd0da5ea5e07
  32. adler32 8 1a0b045d
  33. crc32 8 7813f744
  34. crc32b 8 0d4a1185
  35. fnv132 8 548da96f
  36. fnv1a32 8 d58b3fa7
  37. fnv164 16 7dcf62cdb1910e6f
  38. fnv1a64 16 779a65e7023cd2e7
  39. joaat 8 3e4a5a57
  40. haval128,3 32 906c1df7cbe6d318f36ab172f95e89c0
  41. haval160,3 40 6e733b21876e47c2168a122e23d86bdd69e50f95
  42. haval192,3 48 ec67a6a417953fdbf3496502004b6c21b270d5890dedd931
  43. haval224,3 56 766879d9ba1dc9e24a6040908a7ae813a47b08af5c5f3beebcacda48
  44. haval256,3 64 45492c6c8adab277759f4381420799431a037daf6d829b8b5c21104c10f61a92
  45. haval128,4 32 c97d46956b8e3e60acd2bb090c482c5e
  46. haval160,4 40 2cb8b12eb5a2561022010c2a2af8795e602fdef2
  47. haval192,4 48 39a281e4e492533b6dfea0af294149ccac771ab87204c9ec
  48. haval224,4 56 3d64d34aea48f5e649ed6147da5d29d31c762a937e9e21f4da1f3106
  49. haval256,4 64 0359a526d77e271707c44d9b270e68a394f8486a459f0137ad5e1d02e44c5889
  50. haval128,5 32 8332ad9f32e385d9acd421b63ee04cfc
  51. haval160,5 40 d33cf9052d55da9b0f506cb8849097939363e361
  52. haval192,5 48 67c3492878c8fc4819c8589231fcfe69b15b015c1ca48ac5
  53. haval224,5 56 6bedeb6a8676e46413c020c8813c022486ca93353b8a0673fb577ba1
  54. haval256,5 64 f5f6ffcfe39a65ac2c3989430340420341762a6624ebd69b9d08ec1dc4b9f167

性能测试如下:

  1. <?php
  2. define('testtime', 1000000);
  3. $algos = hash_algos();
  4. foreach($algos as $algo) {
  5. $st = microtime();
  6. for($i = 0; $i < testtime; $i++) {
  7. hash($algo, microtime().$i);
  8. }
  9. $et = microtime();
  10. list($ss, $si) = explode(' ', $st);
  11. list($es, $ei) = explode(' ', $et);
  12. $time[$algo] = $ei + $es - $si - $ss;
  13. }
  14. asort($time, SORT_NUMERIC);
  15. print_r($time);
  16. ?>
  17. Array
  18. (
  19. [fnv1a32] => 1.4528379546356
  20. [fnv164] => 1.4598390410767
  21. [fnv1a64] => 1.4685498960724
  22. [fnv132] => 1.4695508840027
  23. [crc32b] => 1.480463955719
  24. [adler32] => 1.481206043457
  25. [joaat] => 1.4851269485474
  26. [crc32] => 1.508364085907
  27. [md4] => 1.6973789288788
  28. [md5] => 1.7637529927979
  29. [sha1] => 1.932477017334
  30. [tiger128,3] => 1.9683119142761
  31. [tiger160,3] => 1.9759550503387
  32. [ripemd128] => 2.0003409449921
  33. [tiger192,3] => 2.0107291056519
  34. [tiger128,4] => 2.0609339611664
  35. [tiger160,4] => 2.0614830404358
  36. [ripemd256] => 2.1055679496613
  37. [tiger192,4] => 2.1089930283813
  38. [ripemd320] => 2.3564790057831
  39. [ripemd160] => 2.3820580299072
  40. [sha256] => 2.3944439311981
  41. [sha224] => 2.4205659084473
  42. [haval128,3] => 2.5319820201874
  43. [haval224,3] => 2.5319839861755
  44. [haval160,3] => 2.5347460784149
  45. [haval192,3] => 2.5500600071869
  46. [haval256,3] => 2.580485933548
  47. [sha384] => 2.6736448852386
  48. [sha512] => 2.721533025589
  49. [haval224,4] => 2.9019400155029
  50. [haval128,4] => 2.9155439011078
  51. [haval256,4] => 2.9168769813385
  52. [haval160,4] => 2.9341630749512
  53. [haval192,4] => 2.9478991126251
  54. [haval192,5] => 3.1933639251862
  55. [haval256,5] => 3.1942859609985
  56. [haval160,5] => 3.1946619862823
  57. [whirlpool] => 3.1954451004639
  58. [haval128,5] => 3.2122300287323
  59. [haval224,5] => 3.295264964798
  60. [gost] => 4.6756690344391
  61. [gost-crypto] => 4.6819899302826
  62. [snefru] => 6.5784390528107
  63. [snefru256] => 6.6484970919647
  64. [md2] => 11.291653894501
  65. )

php各类hash算法长度及性能的更多相关文章

  1. MurmurHash算法:高运算性能,低碰撞率的hash算法

    MurmurHash算法:高运算性能,低碰撞率,由Austin Appleby创建于2008年,现已应用到Hadoop.libstdc++.nginx.libmemcached等开源系统.2011年A ...

  2. 对一致性Hash算法,Java代码实现的深入研究

    一致性Hash算法 关于一致性Hash算法,在我之前的博文中已经有多次提到了,MemCache超详细解读一文中"一致性Hash算法"部分,对于为什么要使用一致性Hash算法.一致性 ...

  3. 一致性hash算法简介与代码实现

    一.简介: 一致性hash算法提出了在动态变化的Cache环境中,判定哈希算法好坏的四个定义: 1.平衡性(Balance) 2.单调性(Monotonicity) 3.分散性(Spread) 4.负 ...

  4. hash算法

    作者:July.wuliming.pkuoliver 说明:本文分为三部分内容, 第一部分为一道百度面试题Top K算法的详解:第二部分为关于Hash表算法的详细阐述:第三部分为打造一个最快的Hash ...

  5. 常用的Hash算法

    1.RSHash unsigned int RSHash(const std::string& str) {    unsigned int b    = 378551;    unsigne ...

  6. 常见hash算法的原理

    散列表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法.顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙. 散列表(Hash table,也叫 ...

  7. Hash算法初见

    hash算法 (hashmap 实现原理)   Hash ,一般翻译做“ 散列” ,也有直接音译为“ 哈希” 的,就是把任意长度的输入(又叫做预映射, pre-image ),通过散列算法,变换成固定 ...

  8. Java实现一致性Hash算法深入研究

    一致性Hash算法 关于一致性Hash算法,在我之前的博文中已经有多次提到了,MemCache超详细解读一文中”一致性Hash算法”部分,对于为什么要使用一致性Hash算法和一致性Hash算法的算法原 ...

  9. 字符串经典的hash算法

    1 概述 链表查找的时间效率为O(N),二分法为log2N,B+ Tree为log2N,但Hash链表查找的时间效率为O(1). 设计高效算法往往需要使用Hash链表,常数级的查找速度是任何别的算法无 ...

随机推荐

  1. BuildSigar

    https://support.hyperic.com/display/SIGAR/Home;jsessionid=7436F86CA13B66BCE1A827043E159F34#Home-down ...

  2. Linux下 fcntl 函数用法说明

    功能描述:根据文件描述词来操作文件的特性. 文件控制函数         fcntl -- file control LIBRARY         Standard C Library (libc, ...

  3. Java String.replace()方法

    Java String.replace()方法用法实例教程, 返回一个新的字符串,用newChar替换此字符串中出现的所有oldChar 声明 以下是java.lang.String.replace( ...

  4. HealthKit框架参考(转)

    来自:http://www.cocoachina.com/ios/20140915/9624.html 本文由CocoaChina翻译组成员 唧唧歪歪(微博) 翻译自苹果官方文档:The Health ...

  5. java基础之高级应用

    在程序中涉及方法重写的地方使用@override Annotation(只作用于方法)注释可以很好的避免由于重写方法名字过长而造成的程序后期出现的难以调试的错误,特别是程序没有报任何的错误时,而程序的 ...

  6. JS前端知识模块大全

    公司前端:小胖提供,表示感谢 1. 基础 HTML, CSS, JS 文档 W3CSCHOOL: http://www.w3schools.com/ MDN: https://developer.mo ...

  7. html系列教程--描述

    什么是 HTML? HTML 是用来描述网页的一种语言. HTML 指的是超文本标记语言 (Hyper Text Markup Language) HTML 不是一种编程语言,而是一种标记语言 (ma ...

  8. 【整理】Ajax异步实现的几种方式总结

    AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术.GET ...

  9. User cannot be resolved to a type

    出现 User cannot be resolved to a type 不知道具体问题出在哪里但是我经过将全路径输入并保存后错误消失 将User选上,然后点击保存就可以了! 最后我发现错误消失了!

  10. ecmall 点滴记录

    /* 取得列表数据 */ $model_wish =& m('wish'); $wish= $model_wish->find(array( 'conditions' => 'us ...