Python内置模块hashlib、hmac与uuid用法分析


Posted in Python onFebruary 12, 2018

本文实例讲述了Python内置模块hashlib、hmac与uuid用法。分享给大家供大家参考,具体如下:

一、hashlib

md5和sha算法通过消息摘要算法生成定长的消息摘要,消息摘要算法是不可逆的。但同一段消息通过摘要算法后得到的值是一样的,可一通过比对消息摘要验证数据的完整性。

sha算法比MD5算法安全,但所需的时间也稍长。

1、原始消息摘要

import hashlib
# ######## md5 ########
hash = hashlib.md5()
hash.update('admin')
print hash.hexdigest()
#21232f297a57a5a743894a0e4a801fc3
# ######## sha1 ########
hash = hashlib.sha1()
hash.update('admin')
print hash.hexdigest(),len(hash.hexdigest())
# d033e22ae348aeb5660fc2140aec35850c4da997 40
# ######## sha256 ########
hash = hashlib.sha256()
hash.update('admin')
print hash.hexdigest(),len(hash.hexdigest())
# 8c6976e5b5410415bde908bd4dee15dfb167a9c873fc4bb8a81f6f2ab448a918 64
# ######## sha384 ########
hash = hashlib.sha384()
hash.update('admin')
print hash.hexdigest(),len(hash.hexdigest())
# 9ca694a90285c034432c9550421b7b9dbd5c0f4b6673f05f6dbce58052ba20e4248041956ee8c9a2ec9f10290cdc0782 96
# ######## sha512 ########
hash = hashlib.sha512()
hash.update('admin')
print hash.hexdigest(),len(hash.hexdigest())
# c7ad44cbad762a5da0a452f9e854fdc1e0e7a52a38015f23f3eab1d80b931dd472634dfac71cd34ebc35d16ab7fb8a90c81f975113d6c7538dc69dd8de9077ec 128

2、加盐(salt)后摘要

由于同一个消息通过摘要算法得到的摘要是相同的,因此可以通过撞库的方式得到原始消息值。解决方式是,添加一个salt拼接原始消息后再进行计算。

import hashlib
# ######## md5 ########
hash = hashlib.md5('898oaFs09f')
hash.update('admin')
print hash.hexdigest()
#以上等价与
hash = hashlib.md5()
hash.update('898oaFs09fadmin')
print hash.hexdigest()

二、HMAC

HAMC它内部对我们创建 key 和 内容 再进行处理然后再加密,相当安全。一般用于挑战应答。

import hashlib
import hmac
h = hmac.new('keysstring')
h.update('hello')
print h.hexdigest(),len(h.hexdigest())
# 2ca7ac50a9bca542e58e0baad15f8383 32

三、UUID

UUID是128位的全局唯一标识符,通常由32字节的字符串表示。它可以保证时间和空间的唯一性,python中称为UUID,其他语言中可能称为GUID。

它通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性。

UUID主要有五个算法,也就是五种方法来实现:

1、uuid1()——基于时间戳。由MAC地址、当前时间戳、随机数生成。可以保证全球范围内的唯一性,但MAC的使用同时带来安全性问题,局域网中可以使用IP来代替MAC。
2、uuid2()——基于分布式计算。环境DCE(Python中没有这个函数)算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。实际中很少用到该方法。
3、uuid3()——基于名字的MD5散列值。通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性,和不同命名空间的唯一性,但同一命名空间的同一名字生成相同的uuid。
4、uuid4()——基于随机数。由伪随机数得到,有一定的重复概率,该概率可以计算出来。
5、uuid5()——基于名字的SHA-1散列值。算法与uuid3相同,不同的是使用 SHA-1算法。

python中没有实现uuid2算法。

import uuid
print uuid.uuid1()
print uuid.uuid3(uuid.NAMESPACE_DNS, 'testme')
print uuid.uuid4()
print uuid.uuid5(uuid.NAMESPACE_DNS, 'testme')
# 1a52b39e-a197-11e6-b5c6-8056f2d4c814
# 7a67f5d4-50fd-36f7-bbeb-1c739ab40b8c
# 0c0cc4f0-6ad0-40d3-a796-119dcfaddf60
# dac48d1f-a443-578c-8754-856842a2f98d
Python 相关文章推荐
python 数据加密代码
Dec 24 Python
Python中的高级数据结构详解
Mar 27 Python
Python简单遍历字典及删除元素的方法
Sep 18 Python
Python获取二维矩阵每列最大值的方法
Apr 03 Python
使用python实现滑动验证码功能
Aug 05 Python
Python列表删除元素del、pop()和remove()的区别小结
Sep 11 Python
Python 最强编辑器详细使用指南(PyCharm )
Sep 16 Python
Python 异常的捕获、异常的传递与主动抛出异常操作示例
Sep 23 Python
Python函数的定义方式与函数参数问题实例分析
Dec 26 Python
Python学习之路之pycharm的第一个项目搭建过程
Jun 18 Python
Python Selenium实现无可视化界面过程解析
Aug 25 Python
python re模块常见用法例举
Mar 01 Python
20个常用Python运维库和模块
Feb 12 #Python
使用python实现BLAST
Feb 12 #Python
Python内置模块logging用法实例分析
Feb 12 #Python
Request的中断和ErrorHandler实例解析
Feb 12 #Python
Python实现Kmeans聚类算法
Jun 10 #Python
Python request设置HTTPS代理代码解析
Feb 12 #Python
python实现聚类算法原理
Feb 12 #Python
You might like
php 禁止页面缓存输出
2009/01/07 PHP
浅析PHP 按位与或 (^ 、&)
2013/06/21 PHP
php网页版聊天软件实现代码
2016/08/12 PHP
PHP获取MySQL执行sql语句的查询时间方法
2018/08/21 PHP
PHP文件操作实例总结【文件上传、下载、分页】
2018/12/08 PHP
tp5 实现列表数据根据状态排序
2019/10/18 PHP
javascript判断ie浏览器6/7版本加载不同样式表的实现代码
2011/12/26 Javascript
jQuery+CSS实现的网页二级下滑菜单效果
2015/08/25 Javascript
vue制作加载更多功能的正确打开方式
2016/10/12 Javascript
微信禁止下拉查看URL的处理方法
2017/09/28 Javascript
简易Vue评论框架的实现(父组件的实现)
2018/01/08 Javascript
nodejs读取本地中文json文件出现乱码解决方法
2018/10/10 NodeJs
js纯前端实现腾讯cos文件上传功能的示例代码
2019/05/14 Javascript
前后端常见的几种鉴权方式(小结)
2019/08/04 Javascript
深入理解redux之compose的具体应用
2020/01/12 Javascript
Vue vm.$attrs使用场景详解
2020/03/08 Javascript
[02:52]2014DOTA2西雅图国际邀请赛 CIS战队巡礼
2014/07/07 DOTA
[13:55]Newbee vs Team Spirit
2018/06/07 DOTA
浅谈Python中数据解析
2015/05/05 Python
python检查指定文件是否存在的方法
2015/07/06 Python
OpenCV2从摄像头获取帧并写入视频文件的方法
2018/08/03 Python
Pandas:Series和DataFrame删除指定轴上数据的方法
2018/11/10 Python
python3.6下Numpy库下载与安装图文教程
2019/04/02 Python
Python 如何优雅的将数字转化为时间格式的方法
2019/09/26 Python
基于python实现破解滑动验证码过程解析
2020/05/28 Python
keras-siamese用自己的数据集实现详解
2020/06/10 Python
Pytorch 高效使用GPU的操作
2020/06/27 Python
利用Python过滤相似文本的简单方法示例
2021/02/03 Python
台湾生鲜宅配:大口市集
2017/10/14 全球购物
写自荐信的注意事项
2014/03/09 职场文书
火箭队口号
2014/06/18 职场文书
2015年乡镇安全生产工作总结
2015/05/19 职场文书
乡镇干部学习心得体会
2016/01/23 职场文书
详解分布式系统中如何用python实现Paxos
2021/05/18 Python
Python基础数据类型tuple元组的概念与用法
2021/08/02 Python
python实现商品进销存管理系统
2022/05/30 Python