Hash算法:
定义:哈希算法又叫散列算法,是将任意长度的二进制值映射为较短的固定长度的二进制值,这个小的二进制值称为哈希值。它的原理其实很简单,就是把一段交易信息转换成一个固定长度的字符串
特点:
1. 信息相同,字符串也相同。
2. 信息相似不会影响字符串相同。
3. 可以生成无数的信息,但是字符串的种类是一定的,所以是不可逆的。
用途:
1、哈希算法可以检验信息是否是相同的,这样的优势可以节省重复文件传送的时间
2、哈希算法还可以检验信息的拥有者是否真实
示例:
# coding:utf-8 # 使用hashlib模块 import hashlib md5 = hashlib.md5() # 应用MD5算法 data = "hello world" md5.update(data.encode('utf-8'))看 print(md5.hexdigest())
自定义哈希:
# coding:utf-8 # 自定义哈希函数 def my_hash(x): return (x % 7) ^ 2 print(my_hash(1)) # 输出结果:3 print(my_hash(2)) # 输出结果:0 print(my_hash(3)) # 输出结果:1 print(my_hash(4)) # 输出结果:6