详解python中的hashlib模块的使用


Posted in Python onApril 22, 2019

hashlib

hashlib主要提供字符加密功能,将md5和sha模块整合到了一起,支持md5,sha1, sha224, sha256, sha384, sha512等算法

hashlib模块

#哈希算法也叫摘要算法,相同的数据始终得到相同的输出,不同的数据得到不同的输出。
#(1)哈希将不可变的任意长度的数据,变成具有固定长度的唯一值
#(2)字典的键值对映射关系是通过哈希计算的,哈希存储的数据是散列(无序)

# 应用场景:在需要效验功能时使用
 用户密码的 => 加密,解密
 相关效验的 => 加密,解密

hashlib中的MD5算法

# 第一步是引包
import hashlib
# 创建一个md5算法的对象
hs = hashlib.md5()
# print(hs)
# update中的 参数必须是二进制字节流 
hs.update("123".encode())
## hexdigest 返回32位十六进制的字符串(固定长度)
## 用一个hsvar来接收经过哈希算法返回的值
hsvar = hs.hexdigest()

#加盐 (就是在简单的算法中进行加入混肴参数)

语法格式如下:

#首先在实例化hashlib中的MD5对象的时候,加入混淆参数key,以此达到更加复杂的加密)

#加入的key参数一定也要是字节流
hs2 = hashlib.md5("abcd".encode())
hs2.update("123123".encode())
hs2var = hs2.hexdigest()

加盐后的好处就是,增加了加密的安全性,使其不那么容易被破解

但因为hash算法是被公开的算法,其安全性不那么好,一些简单的加密 值很容易被逆向破解出来,说逆向破解也不那么准确,

一般来说,破解此类算法只能使用穷举法, 可以将 跑出来的值存入到一个大的数据库中,哈希算法得出的值有唯一性,所以可以反向查询已有的hash值来得到原始数据,当然这种网站也有, 我百度上看到的一个网站,你们可以进去看一看,一般的哈希值都能查询到原数据,只要他们数据库中有的话.

所以说最好的方法就是我们要加盐,去加入复杂混肴参数,这样的话大大提高了数据加密的安全性

链接: https://www.cmd5.com/  md5解密(本链接只作为学习使用,勿将其使用到任何非法用途)

在开发编程中,常用到hash算法的方面应该有用户的注册登录

下面有我写的一个实例,供大家参考(为了方便大家的阅读,这个注册登录功能我没有完善,比如说用正则去卡用户名和密码的格式等等,)

import hashlib
#定义一个加密函数,将传入的参数转换成32位的哈希值并返回
def md5(pwd):
  md5_password = hashlib.md5("abd".encode())
  md5_password.update(pwd.encode())
  return md5_password.hexdigest()
#定义一个登录函数,将传入的账号密码与本地密码文件进行匹配,如果匹配到返回True
def login(user,pwd):
  with open("database","r",encoding="utf-8") as fp:
    for line in fp :
      u,p = line.strip().split("|")
      if u == user and p == md5(pwd):
        return True
#定义一个注册的函数,将用户传入的账号密码写入到本地的密码文件中
def register(user,pwd):
  with open("database","w",encoding="utf-8") as fp:
    temp = user+ "|" + md5(pwd)
    fp.write(temp)
#index菜单,给用户的交互
choice = input("1表示登录, 2表示注册:").strip()
if choice == "2":
  user = input("用户名:")
  pwd = input("密码:")
  register(user,pwd)
elif choice == "1":
  user = input("用户名:")
  pwd = input("密码:")
  r = login(user,pwd)
  if r == True:
    print("登录成功")
  else:
    print("登录失败")
else:
  print("账号不存在")

 hashlib中的sha算法

•# sha 加密效率低,算法精密,安全性高
•sha: Secure Hash Algorithm(安全哈希算法)

 sha是美国国家标准与技术研究院与美国国家安全局设计,从94年以来被广泛使用的加密算法.sha系列中的sha1, sha224, sha2556适用于长度不超过2^64二进制位的消息。sha384和sha512适用于长度不超过2^128二进制位的消息。不过,这个也不太安全.2005年的时候国内王小云教授及其团队在sha1算法的破译上就已经取得了很大的成就.今年谷歌已经攻破了sha1算法.另外,Matthew Green(https://twitter.com/matthew_d_green)在这一领域也有不错的成就.

import hashlib
#实例化sha1对象
hs3 = hashlib.sha1()
#去将要去加密的数据通过一个方法放入对象中
hs3.update('123123'.encode())
#调用对象中的方法,计算并输出加密后的40位的哈希值
hsvar = hs3.hexdigest()

sha算法常用的有 sha1 sha512等,语法一样,只不过输出的哈希值的长度不一样,所以就不一一列举了

总结

以上所述是小编给大家介绍的python中的hashlib模块的使用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
在Python中操作字典之clear()方法的使用
May 21 Python
python处理大数字的方法
May 27 Python
Python实现修改文件内容的方法分析
Mar 25 Python
详解python3中的真值测试
Aug 13 Python
Python中asyncio与aiohttp入门教程
Oct 16 Python
使用Template格式化Python字符串的方法
Jan 22 Python
在python Numpy中求向量和矩阵的范数实例
Aug 26 Python
python 两个数据库postgresql对比
Oct 21 Python
Python模块相关知识点小结
Mar 09 Python
将pycharm配置为matlab或者spyder的用法说明
Jun 08 Python
pytorch 梯度NAN异常值的解决方案
Jun 05 Python
Python 中面向接口编程
May 20 Python
Python 中包/模块的 `import` 操作代码
Apr 22 #Python
python定时检测无响应进程并重启的实例代码
Apr 22 #Python
django query模块
Apr 20 #Python
不到20行代码用Python做一个智能聊天机器人
Apr 19 #Python
详解Python3 基本数据类型
Apr 19 #Python
python面向对象法实现图书管理系统
Apr 19 #Python
python远程连接MySQL数据库
Apr 19 #Python
You might like
自制短波长线天线频率预选器 - 成功消除B2K之流的镜像
2021/03/02 无线电
thinkPHP+PHPExcel实现读取文件日期的方法(含时分秒)
2016/07/07 PHP
JS中==与===操作符的比较
2009/03/21 Javascript
Tab页界面,用jQuery及Ajax技术实现
2009/09/21 Javascript
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
node.js中的fs.readdir方法使用说明
2014/12/17 Javascript
jQuery实现提示密码强度的代码
2015/07/15 Javascript
jQuery插件开发精品教程让你的jQuery提升一个台阶
2016/01/27 Javascript
JS 对象(Object)和字符串(String)互转方法
2016/05/20 Javascript
轮播的简单实现方法
2016/07/28 Javascript
TypeScript入门-基本数据类型
2017/03/28 Javascript
微信小程序之前台循环数据绑定
2017/08/18 Javascript
jQuery 利用ztree实现树形表格的实例代码
2017/09/27 jQuery
js + css实现标签内容切换功能(实例讲解)
2017/10/09 Javascript
vue生成token保存在客户端localStorage中的方法
2017/10/25 Javascript
解决axios发送post请求返回400状态码的问题
2018/08/11 Javascript
微信小程序判断用户是否需要再次授权获取个人信息
2019/07/18 Javascript
js实现简单掷骰子小游戏
2019/10/24 Javascript
react组件基本用法示例小结
2020/04/27 Javascript
Javascript类型判断相关例题及解析
2020/08/26 Javascript
Python+OpenCV目标跟踪实现基本的运动检测
2018/07/10 Python
使用python验证代理ip是否可用的实现方法
2018/07/25 Python
python实现可变变量名方法详解
2019/07/01 Python
python防止随意修改类属性的实现方法
2019/08/21 Python
记录一下scrapy中settings的一些配置小结
2020/09/28 Python
盛大二次面试题
2016/11/18 面试题
Final类有什么特点
2012/04/25 面试题
综治宣传月活动总结
2014/04/28 职场文书
2014年党课学习材料
2014/05/11 职场文书
公安局负责人查摆问题及整改方案
2014/09/27 职场文书
法院授权委托书格式
2014/09/28 职场文书
中学生旷课检讨书模板
2014/10/08 职场文书
二年级学生期末评语
2014/12/26 职场文书
2015年综治维稳工作总结
2015/04/07 职场文书
2015年汽车销售员工作总结
2015/07/24 职场文书
php中pcntl_fork详解
2021/04/01 PHP