2022年2022年哈希算法

上传人:hs****ma 文档编号:567425830 上传时间:2024-07-20 格式:PDF 页数:5 大小:63.38KB
返回 下载 相关 举报
2022年2022年哈希算法_第1页
第1页 / 共5页
2022年2022年哈希算法_第2页
第2页 / 共5页
2022年2022年哈希算法_第3页
第3页 / 共5页
2022年2022年哈希算法_第4页
第4页 / 共5页
2022年2022年哈希算法_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《2022年2022年哈希算法》由会员分享,可在线阅读,更多相关《2022年2022年哈希算法(5页珍藏版)》请在金锄头文库上搜索。

1、哈希算法目录简介计算方法简介计算方法展开编辑本段 简介哈希 算法将任意长度的二进制 值映射 为固定长度的较小二进制值,这个小的二进制值称为哈希值。哈希值是一段数据唯一且极其紧凑的数值 表示形式。如果散列一段明文而且哪怕只更改该段落的一个字母,随后的哈希都将产生不同的值。要找到散列为同一个值的两个不同的输入,在计算上是不可能的,所以数据的哈希值 可以检验数据的完整性。哈希表是根据设定的哈希函数H(key) 和处理冲突方法将一组关键字映象到一个有限的地址区间上,并以关键字在地址区间中的象作为记录在表中的存储位置,这种表称为哈希表 或散列,所得存储位置称为哈希地址或散列地址。作为线性数据结构与表格和

2、队列等相比,哈希表无疑是查找速度比较快的一种。哈希通过将单向数学函数(有时称为“哈希算法”)应用到任意数量的数据所得到的固定大小的结果。如果输入数据中有变化,则哈希也会发生变化。哈希可用于许多操作,包括身份验证和数字签名 。 也称为“ 消息摘要 ”。编辑本段 计算方法哈希算法用来产生一些数据片段(例如消息或会话项)的哈希值的算法。使用好的哈希算法,在输入数据中所做的更改就可以更改结果哈希值中的所有位;因此,哈希对于检测数据对象(例如消息)中的修改很有用。此外,好的哈希算法使得构造两个相互独立且具有相同哈希的输入不能通过计算方法实现。典型的哈希算法包括 MD2、MD4 、MD5 和 SHA-1

3、。哈希算法也称为“哈希函数”。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 5 页 - - - - - - - - - 另请参阅:基于哈希的消息验证模式 (HMAC), MD2, MD4, MD5, 消息摘要 , 安全哈希算法 (SHA-1) MD5一种符合工业标准的单向 128 位哈希方案, 由 RSA Data Security, Inc. 开发。各种“点对点协议(PPP)”供应商都将它用于加密的身份验证。哈希方案是一种以结果唯一并且不能返回到其原始格式的方式来转换

4、数据(如密码)的方法。质询握手身份验证协议 (CHAP) 使用质询响应并在响应时使用单向 MD5 哈希法。按照此方式,您无须通过网络发送密码就可以向服务器证明您知道密码。质询握手身份验证协议(CHAP) “点对点协议(PPP)”连接的一种质询响应验证协议,在 RFC 1994 中有所描述。该协议使用业界标准 MD5 哈希算法来哈希质询串(由身份验证服务器所发布)和响应中的用户密码的组合。点对点协议 (PPP) 用点对点链接来传送多协议数据报的行业标准协议套件。RFC 1661 中有关于 PPP 的文档。另请参阅:压缩控制协议 (CCP), 远程访问 , 征求意见文档 (RFC), 传输控制协议

5、/Internet 协议 (TCP/IP), 自主隧道几个比较著名的哈希算法class GeneralHashFunctionLibrary public long RSHash(String str) int b = 378551; int a = 63689; long hash = 0; for(int i = 0; i str.length(); i+) hash = hash * a + str.charAt(i); a = a * b; return hash; public long JSHash(String str) long hash = 1315423911; 名师资料总

6、结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 5 页 - - - - - - - - - for(int i = 0; i str.length(); i+) hash = (hash 2); return hash; public long PJWHash(String str) long BitsInUnsignedInt = (long)(4 * 8); long ThreeQuarters = (long)(BitsInUnsignedInt * 3) / 4); lon

7、g OneEighth = (long)(BitsInUnsignedInt / 8); long HighBits = (long)(0xFFFFFFFF) (BitsInUnsignedInt - OneEighth); long hash = 0; long test = 0; for(int i = 0; i str.length(); i+) hash = (hash ThreeQuarters) & (HighBits); return hash; public long ELFHash(String str) long hash = 0; long x = 0; for(int

8、i = 0; i str.length(); i+) hash = (hash 24); hash &= x; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 5 页 - - - - - - - - - return hash; public long BKDRHash(String str) long seed = 131; / 31 131 1313 13131 131313 etc. long hash = 0; for(int i = 0; i str.lengt

9、h(); i+) hash = (hash * seed) + str.charAt(i); return hash; public long SDBMHash(String str) long hash = 0; for(int i = 0; i str.length(); i+) hash = str.charAt(i) + (hash 6) + (hash 16) - hash; return hash; public long DJBHash(String str) long hash = 5381; for(int i = 0; i str.length(); i+) hash =

10、(hash 5) + hash) + str.charAt(i); return hash; public long DEKHash(String str) long hash = str.length(); for(int i = 0; i str.length(); i+) hash = (hash 27) str.charAt(i); return hash; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 5 页 - - - - - - - - - public

11、long BPHash(String str) long hash = 0; for(int i = 0; i str.length(); i+) hash = hash 7 str.charAt(i); return hash; public long FNVHash(String str) long fnv_prime = 0x811C9DC5; long hash = 0; for(int i = 0; i str.length(); i+) hash *= fnv_prime; hash = str.charAt(i); return hash; public long APHash(String str) long hash = 0xAAAAAAAA; for(int i = 0; i str.length(); i+) if (i & 1) = 0) hash = (hash 3); else hash = (hash 5); return hash; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 5 页 - - - - - - - - -

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号