一、hashlib模块

1 hash是什么

hash是一种算法(Python3.版本里使用hashlib模块代替了md5模块和sha模块,主要提供 SHA1、SHA224、SHA256、SHA384、SHA512、MD5 算法),该算法接受传入的内容,经过运算得到一串hash值。

2 hash值的特点

  • 只要传入的内容一样,得到的hash值一样,可用于非明文密码传输时密码校验
  • 不能由hash值返解成内容,即可以保证非明文密码的安全性
  • 只要使用的hash算法不变,无论校验的内容有多大,得到的hash值长度是固定的,可以用于对文本的哈希处理

hash算法其实可以看成一座工厂,工厂接收你送来的原材料,经过加工返回的产品就是hash值

import hashlibm = hashlib.md5()
m.update('hello'.encode('utf8'))
print(m.hexdigest())
#5d41402abc4b2a76b9719d911017c592m.update('hash'.encode('utf8'))
print(m.hexdigest())
#97fa850988687b8ceb12d773347f7712m2 = hashlib.md5()
m2.update('hellohash'.encode('utf8'))
print(m2.hexdigest())
#97fa850988687b8ceb12d773347f7712m3 = hashlib.md5()
m3.update('hello'.encode('utf8'))
print(m3.hexdigest())
#5d41402abc4b2a76b9719d911017c592

3 撞库破解hash算法加密

hash加密算法虽然看起来很厉害,但是他是存在一定缺陷的,即可以通过撞库可以反解,如下代码所示。

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import hashlib
# 假定我们知道hash的微信会设置如下几个密码
pwd_list = ['hash3714','hash1313','hash94139413','hash123456','123456hash','h123ash',
]def make_pwd_dic(pwd_list):dic = {}for pwd in pwd_list:m = hashlib.md5()m.update(pwd.encode('utf-8'))dic[pwd] = m.hexdigest()return dicdef break_code(hash_pwd, pwd_dic):for k, v in pwd_dic.items():if v == hash_pwd:print('hash的微信的密码是===>%s' % k)hash_pwd = '0562b36c3c5a3925dbe3c4d32a4f2ba2'
break_code(hash_pwd, make_pwd_dic(pwd_list))
hash的微信的密码是===>hash123456

为了防止密码被撞库,我们可以使用python中的另一个hmac 模块,它内部对我们创建key和内容做过某种处理后再加密。

如果要保证hmac模块最终结果一致,必须保证:

  • hmac.new括号内指定的初始key一样
  • 无论update多少次,校验的内容累加到一起是一样的内容
import hmac
# 注意hmac模块只接受二进制数据的加密
h1 = hmac.new(b'hash')
h1.update(b'hello')
h1.update(b'world')
print(h1.hexdigest())
#905f549c5722b5850d602862c34a763eh2 = hmac.new(b'hash')
h2.update(b'helloworld')
print(h2.hexdigest())
#905f549c5722b5850d602862c34a763eh3 = hmac.new(b'hashhelloworld')
print(h3.hexdigest())
#a7e524ade8ac5f7f33f3a39a8f63fd25

Python基础教程:hashlib和hmac模块相关推荐

  1. Python hashlib、hmac模块

    Python中的用于加密的函数位于hashlib,hmac模块中,都是内置模块,直接导入即可使用 hashlib模块实现了md5,sha1,sha224,sha256,sha384,sha512等算法 ...

  2. python黑马教程ppt_,python基础教程 PPT

    python基础教程 PPT Python我这里有Python编开发,进阶,化,实战等系列视频教程,还有安装包,素材,代码内容,这里就不一一说了,全套内容一共300G左右,非常的详细,需要的请到网盘下 ...

  3. Python基础教程学习笔记:第一章 基础知识

    Python基础教程 第二版 学习笔记 1.python的每一个语句的后面可以添加分号也可以不添加分号:在一行有多条语句的时候,必须使用分号加以区分 2.查看Python版本号,在Dos窗口中输入&q ...

  4. python基础教程博客_python基础教程(一)

    之所以选择py交易有以下几点:1.python是胶水语言(跨平台),2.python无所不能(除了底层),3.python编写方便(notepad++等文本编辑器就能搞事情),4.渗透方面很多脚本都是 ...

  5. python基础教程第二版和第三版哪个好-python基础教程 2版和3版哪个适合新手?!...

    python基础教程 2版和3版哪个适合新手? 现在学是学python3. 两者的差异发者本身影响并不大,个别语法细微的差比如python3的print数方式使用,一些常用模块的名称差异,一些机制的差 ...

  6. python基础教程第二版答案-《Python基础教程》(第2版修订版)中要注意的地方...

    想必现在大家学习Python都会用3.0及以上的版本了,虽然2.X的版本依然很多,但是这两年随着部分开源项目不再支持2.X版本,3.X已经成为趋势. 正是在这样的大背景下,我最近用这本<Pyth ...

  7. python基础教程视频(全13集)-Python基础视频教程(600集)【传智播客精品教程】...

    Python基础视频教程 初级共600节课 本套视频是传智播客紧抓未来最大趋势--人工智能,应运而生的一套Python入门视频教程,Python是学习人工智能的首选语言,而该视频是专门针对零基础的学员 ...

  8. python基础教程第三版和第二版选哪个-python基础教程 2版和3版哪个适合新手?!...

    python基础教程 2版和3版哪个适合新手? 现在学是学python3. 两者的差异发者本身影响并不大,个别语法细微的差比如python3的print数方式使用,一些常用模块的名称差异,一些机制的差 ...

  9. python基础教程第二版和第三版有什么区别-《Python基础教程》(第2版修订版)中要注意的地方...

    想必现在大家学习Python都会用3.0及以上的版本了,虽然2.X的版本依然很多,但是这两年随着部分开源项目不再支持2.X版本,3.X已经成为趋势. 正是在这样的大背景下,我最近用这本<Pyth ...

最新文章

  1. idea解决打开大文件消耗CPU问题
  2. 从来都没有爱情发生的人生
  3. 青蛙跳台阶问题——剑指offer
  4. Shell第一个脚本-添加用户
  5. java 集合反射_关于granite源码包CollectionUtil集合工具类获取集合反射类型、实例化各种集合类型HashSet/ArrayList等...
  6. MacBook笔记本的几个快捷键的使用(学会事半功倍)
  7. Socket编程实践(5) --TCP粘包问题与解决
  8. python format 时间格式
  9. ElementUI下拉框选择后不显示值
  10. qqkey获取原理_通过call获取qqkey支持最新版
  11. MATLAB生成(对角线上元素相同的)三对角矩阵的实例
  12. “电容触摸按键实验”实例解析
  13. 软考网络工程师历年知识点总结(结合历年来真题内容总结)
  14. 【办公】Gmail的常用方法以及小技巧
  15. 远程桌面连接时无法访问远程计算机的计算机属性提示系统调用失败,远程过程调用失败【应对技巧】...
  16. c语言sdk,C/C++ SDK
  17. 程序员简历优化指南-安晓辉-专题视频课程
  18. (swing读书笔记)Swing Look And Feel(3)
  19. Leetcode 738. 单调递增的数字
  20. 《液晶显示器和液晶电视维修核心教程》——2.4 三极管类

热门文章

  1. HDU1257 最少拦截系统(下降自序列个数)
  2. IIS不支持apk文件下载问题
  3. ORA-20204 错误
  4. 计算机在课堂中的应用论文,任务教学法在计算机教学中的应用论文
  5. unity 继承会调用start吗_Unity 继承MonoBehaviour脚本 执行顺序 详解
  6. 小强升职记梗概_解读《小强升职记》——一本关于时间管理的书
  7. 【学习笔记】JS进阶语法一document对象
  8. 【转载】如何在归档后启用归档信息系统
  9. pp模块中关于物料反冲的探讨
  10. 外国人起争执时最常说的话