【18】哈希算法

1. 什么是哈希算法?

  1. 定义
    将任意长度的二进制值串映射成固定长度的二进制值串,这个映射的规则就是哈希算法,而通过原始数据映射之后得到的二进制值串就是哈希值。
  2. 如何设计一个优秀的哈希算法?
    1)单向哈希:
    从哈希值不能反向推导出哈希值(所以哈希算法也叫单向哈希算法)。
    2)篡改无效:
    对输入敏感,哪怕原始数据只修改一个Bit,最后得到的哈希值也大不相同。
    3)散列冲突:
    散列冲突的概率要很小,对于不同的原始数据,哈希值相同的概率非常小。
    4)执行效率:
    哈希算法的执行效率要尽量高效,针对较长的文本,也能快速计算哈希值。

2. 哈希算法的常见应用有哪些?

7个常见应用:安全加密、唯一标识、数据校验、散列函数、负载均衡、数据分片、分布式存储。

  1. 安全加密
    1)常用于加密的哈希算法:
    MD5:MD5 Message-Digest Algorithm,MD5消息摘要算法
    SHA:Secure Hash Algorithm,安全散列算法
    DES:Data Encryption Standard,数据加密标准
    AES:Advanced Encryption Standard,高级加密标准
    2)对用于加密的哈希算法,有两点格外重要,第一点是很难根据哈希值反向推导出原始数据,第二点是散列冲突的概率要小。
    3)在实际开发中要权衡破解难度和计算时间来决定究竟使用哪种加密算法。
  2. 唯一标识
    通过哈希算法计算出数据的唯一标识,从而用于高效检索数据。
  3. 数据校验
    利用哈希算法对输入数据敏感的特点,可以对数据取哈希值,从而高效校验数据是否被篡改过。
  4. 散列函数
    散列函数中用到的哈希算法更加关注散列后的值能不能平均分布,以及散列函数的执行快慢。
  5. 负载均衡(哈希算法代替映射表)
    【需求】
    如何实现一个会话粘滞(ses
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值