首页 > 语言 > JavaScript > 正文

javascript实现获取字符串hash值

2024-05-06 16:19:49
字体:
来源:转载
供稿:网友

Hash 可以看作是一个 关联数组,它对每一个值都绑定了一个唯一的键(值并不必须是唯一的), 然而,它不能保证迭代时元素的顺序始终一致。因为 JavaScript 程序语言的特性,每个对象实际上都是一个 hash,下面我们就来详细探讨下。

性能很高的计算字符串或文件hash值的函数,比md5速度快得多,自己一直用着,重复的几率为很底,一般的应用足够,

 

 
  1. var I64BIT_TABLE = 
  2. 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_-'.split(''); 
  3.  
  4. function hash(input){ 
  5. var hash = 5381; 
  6. var i = input.length - 1; 
  7.  
  8. if(typeof input == 'string'){ 
  9. for (; i > -1; i--) 
  10. hash += (hash << 5) + input.charCodeAt(i); 
  11. else
  12. for (; i > -1; i--) 
  13. hash += (hash << 5) + input[i]; 
  14. var value = hash & 0x7FFFFFFF; 
  15.  
  16. var retValue = ''
  17. do
  18. retValue += I64BIT_TABLE[value & 0x3F]; 
  19. while(value >>= 6); 
  20.  
  21. return retValue; 

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选