详解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中对列表排序实例
Jan 04 Python
深入浅析ImageMagick命令执行漏洞
Oct 11 Python
如何实现删除numpy.array中的行或列
May 08 Python
python买卖股票的最佳时机(基于贪心/蛮力算法)
Jul 05 Python
python2 中 unicode 和 str 之间的转换及与python3 str 的区别
Jul 25 Python
matplotlib绘制多个子图(subplot)的方法
Dec 03 Python
python 读取更新中的log 或其它文本方式
Dec 24 Python
windows支持哪个版本的python
Jul 03 Python
PIP和conda 更换国内安装源的方法步骤
Sep 21 Python
Python页面加载的等待方式总结
Feb 28 Python
python 下载文件的几种方式分享
Apr 07 Python
python基础之//、/与%的区别详解
Jun 10 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
PHP函数实现从一个文本字符串中提取关键字的方法
2015/07/01 PHP
对于Laravel 5.5核心架构的深入理解
2018/02/22 PHP
json简单介绍
2008/06/10 Javascript
JavaScript 学习笔记二 字符串拼接
2010/03/28 Javascript
Ajax 数据请求的简单分析
2011/04/05 Javascript
javascript 进阶篇3 Ajax 、JSON、 Prototype介绍
2012/03/14 Javascript
使用jquery动态加载javascript以减少服务器压力
2012/10/29 Javascript
Jquery刷新页面背景图片随机变换的实现方法
2013/03/15 Javascript
在jquery中combobox多选的不兼容问题总结
2013/12/24 Javascript
常用jQuery选择器总结
2014/07/11 Javascript
Javascript实现单张图片浏览
2014/12/18 Javascript
JQuery中DOM加载与事件执行实例分析
2015/06/13 Javascript
探究JavaScript函数式编程的乐趣
2015/12/14 Javascript
Bootstrap按钮组件详解
2016/04/26 Javascript
深入浅析JavaScript中的Function类型
2016/07/09 Javascript
AngularJS实现标签页的两种方式
2016/09/05 Javascript
textarea 在浏览器中固定大小和禁止拖动的实现方法
2016/12/03 Javascript
浅谈Node.js:fs文件系统模块
2016/12/08 Javascript
基于Require.js使用方法(总结)
2017/10/26 Javascript
原生JS实现动态添加新元素、删除元素方法
2019/05/05 Javascript
Vue项目实现简单的权限控制管理功能
2019/07/17 Javascript
Antd-vue Table组件添加Click事件,实现点击某行数据教程
2020/11/17 Javascript
[00:48]DOTA2国际邀请赛公开赛报名开始 扫码开启逐梦之旅
2018/06/06 DOTA
python ---lambda匿名函数介绍
2019/03/13 Python
pytorch实现用Resnet提取特征并保存为txt文件的方法
2019/08/20 Python
python线程的几种创建方式详解
2019/08/29 Python
Python绘制热力图示例
2019/09/27 Python
Python函数生成器原理及使用详解
2020/03/12 Python
Python 解析简单的XML数据
2020/07/24 Python
Python实现爬取网页中动态加载的数据
2020/08/17 Python
Nike西班牙官方网站:Nike.com (ES)
2017/10/30 全球购物
求职面试个人自我评价
2014/02/28 职场文书
毕业生个人自荐书
2015/03/05 职场文书
大学生心理健康活动总结
2015/05/08 职场文书
爱心捐助活动总结
2015/05/09 职场文书
JavaScript原型链中函数和对象的理解
2022/06/16 Javascript