一、概述

在程序开发过程中,很多时候会涉及用户信息验证环节,这类场景下我们往往需要对字符串进行加密处理。python中也有专门的加密模块,它就是hashlib。下面章节将详述它的常见用法。

二、常见加密算法的使用

hashlib模块支持业界主流常见的一些加密算法,如md5,sha1,sha256,sha384,sha 512,hmac加密等,具体用法都差不多,只是调用的算法不同而已。需要注意的是,在输入需要被加密的字符串时,必须先encode等二进制串,所以在字符串前面要加上b。

2.1 md5加密

直接上代码把,没有太多可以讲述的了。

  1 import hashlib
2
3 m = hashlib.md5() #创建一个md5对象,即通过md5加密处理
4 m.update(b'python') #此处传递的字符串需要encode成二进制,前面加b
5 print(m.hexdigest()) #以16进制输出
6
7 输出:
8 23eeeb4347bdd26bfc6b7ee9a3b755dd

注意:
这里的update有点类似于append的作用,当我们连续两次update后输出时,最后输出的md5码并非最后一次update的字符串对应的md5码,而是对此前所有update的字符串的拼接后计算出的md5码,当然前提是update前面的对象是同一个。

如何验证这个结论呢?代码奉上:

  1 import hashlib
2
3 m = hashlib.md5()
4 m.update(b'py')
5 print(m.hexdigest())
6 m.update(b'thon')
7 print(m.hexdigest())
8 print('-------')
9 n = hashlib.md5()
10 n.update(b'python')#一次性update一个字符串
11 print(n.hexdigest())
12 print('========')
13 o = hashlib.md5()
14 o.update(b'py'+b'thon')#自行拼接字符串输出
15 print(o.hexdigest())
16
17 输出:
18 dfed5bc177b87ab317c584e06566adc6
19 23eeeb4347bdd26bfc6b7ee9a3b755dd
20 -------
21 23eeeb4347bdd26bfc6b7ee9a3b755dd
22 ========
23 23eeeb4347bdd26bfc6b7ee9a3b755dd

从以上代码可以看出,对同一个md5对象多次update字符串,输出的md5码实际是对多个字符串拼接后的md5计算。这里也给我们一个启示,如果要计算一个文件的md5码,如果文件长度不会对机器的硬件资源造成压力,一次性读取内容后进行md5计算是最快捷的方式了。

2.2 sha1加密

如上文所述,其他算法的用法非常类似,只是调用的算法不同罢了。

  1 import hashlib
2
3 m = hashlib.sha1()
4 m.update(b'sha1')
5 print(m.hexdigest())
6
7
8 输出:
9 415ab40ae9b7cc4e66d6769cb2c08106e8293b48

2.3 sha256加密

如法炮制sha256算法

  1 import hashlib
2
3 m = hashlib.sha256()
4 m.update(b'sha1')
5 print(m.hexdigest())
6 输出:
7 b1565820a5cdac40e0520d23f9d0b1497f240ddc51d72eac6423d97d952d444f

2.4 sha512加密

看看sha512算法把。

  1 import hashlib
2
3 m = hashlib.sha512()
4 m.update(b'sha1')
5 print(m.hexdigest())
6
7 输出:
8 4af46fa0152c825afee230022f46e3aedb0a9ee2a3dc20e30821a4d263327074b26455f29578812876011dd921132c6ed813b38d16b1b2a1c1fa7cea1a6b1fd9

2.5 hmac加密

以上加密算法主要用于字符串的加密处理,还有一种用于身份验证可防窃听的加密算法,它就是hmac加密。散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制,是一种基于密钥的哈希算法的认证协议。

HMAC加密算法是一种基于密钥的报文完整性的验证方法,其安全性是建立在Hash加密算法基础上的。它要求通信双方共享密钥、约定算法、对报文进行Hash运算,形成固定长度的认证码。通信双方通过认证码的校验来确定报文的合法性。HMAC加密算法可以用来作加密、数字签名、报文验证等。

HMAC加密算法的定义

HMAC加密算法是一种执行“校验和”的算法,它通过对数据进行“求和”来检查数据是否被更改了。在发送数据以前,HMAC加密算法对数据块和双方约定的公钥进行“散列操作”,以生成称为“摘要”的东西,附加在待发送的数据块中。当数据和摘要到达其目的地时,就使用HMAC加密算法来生成另一个校验和,如果两个数字相匹配,那么数据未被做任何篡改。否则,就意味着数据在传输或存储过程中被某些居心叵测的人作了手脚。

实际的典型应用场景是挑战/响应”(Challenge/Response)身份认证,认证流程如下:

(1) 客户端向服务器发出一个验证请求。

(2) 服务器接到此请求后生成一个随机数并通过网络传输给客户端(此为挑战)。

(3) 客户端将收到的随机数结合本地的密码,通过双方约定一致的算法进行HMAC-MD5运算并得到一个结果作为认证证据传给服务器(此为响应)。

(4) 与此同时,服务器也使用该随机数与存储在服务器数据库中的该客户密钥进行HMAC-MD5运算,如果服务器的运算结果与客户端传回的响应结果相同,则认为客户端是一个合法用户。

以上是理论背景知识,python中的用法如下:

  1 import hmac
2 h = hmac.new(b'hi', b'python') #这里的hi是双方随机生成的数据块,相当于额外加的料,python才是真正的核心数据
3 print(h.hexdigest())
4
5 输出:
6 392e75a856ddb4f8203ef82f7f21b391

三、关于加密算法

以上讲述了python中典型的加密算法的使用。实际上加密算法和密码学的理论博大精深,在实际应用中还需要结合各种算法的特点来进行选择,在安全性和计算效率之间取得一个可满足需求的平衡点(如md5的算法安全性堪忧,sha512的输出明显比sha1要复杂得多,另外还有des、3des等算法等等)。

day5-hashlib模块的更多相关文章

  1. 小白的Python之路 day5 hashlib模块

    hashlib模块 一.概述 用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法 二.算法的演 ...

  2. day5模块学习--hashlib模块

    hashlib模块     Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 什么是摘要算法呢?摘要算法又称哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度 ...

  3. Python学习-day5 常用模块

    day5主要是各种常用模块的学习 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 conf ...

  4. python标准模块(time、datetime及hashlib模块)

    一.time,datetime模块 时间相关的操作 import time time.sleep(5) # ==> 停顿多少秒 print(time.time()) # ==> 返回时间戳 ...

  5. Python 之路 Day5 - 常用模块学习

    本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configpars ...

  6. Python hashlib模块 (主要记录md5加密)

    python提供了一个进行hash加密的模块:hashlib 下面主要记录下其中的md5加密方式(sha1加密一样把MD5换成sha1) >>> import hashlib > ...

  7. python 学习day5(模块)

    一.模块介绍 模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能 ...

  8. Python学习笔记——基础篇【第六周】——hashlib模块

    常用模块之hashlib模块 用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法 import ...

  9. Python之数据加密与解密及相关操作(hashlib模块、hmac模块、random模块、base64模块、pycrypto模块)

    本文内容 数据加密概述 Python中实现数据加密的模块简介 hashlib与hmac模块介绍 random与secrets模块介绍 base64模块介绍 pycrypto模块介绍 总结 参考文档 提 ...

  10. Python模块之hashlib模块、logging模块

    一.hashlib模块 hashlib模块介绍:hashlib这个模块提供了摘要算法,例如 MD5.hsa1 摘要算法又称为哈希算法,它是通过一个函数,把任意长度的数据转换为一个长度固定的数据串,这个 ...

随机推荐

  1. Linux学习笔记(13)linux软件安装rpm与yum--理论篇

    该文章linux知识点如下 1.linux中 软件包介绍 2.linux源码软件安装 3.linux二进制软件安装 4.linux rpm软件包管理 5.linux yum软件包管理 1.linux中 ...

  2. 手机调取摄像头问题(getUserMedia)

    先说坏消息,苹果机没法玩这个!!! 而且,必须拥有 https 的安全协议!!! 而安卓机想完成这个功能倒是很 easy 的,看一眼代码 主要传入三个参数,配置对象,成功,失败 var mediaOp ...

  3. 编写Tesseract的Python扩展

    Tesseract是一个开源的OCR(光学字符识别)引擎,用于识别并输出图片中的文字.虽然和商业软件比起来识别精度不算很高,但是如果你要寻找免费开源的OCR引擎,可能Tesseract就是唯一的选择了 ...

  4. Dubbo与微服务

    http访问到服务器要经过的内容:Nginx —Tomcat –db,nginx就是一个负载均衡左右.又一次面试问到了我nginx的反向代理.现在想了想面试官要问的应该是 域名的反向代理,就是使用一个 ...

  5. vue项目配置less预编译语言

    当所有东西都 准备好之后 : 第一步: 安装less依赖,npm install less less-loader --save 第二步:找到webpack配置文件webpack.base.conf. ...

  6. 20145222 黄亚奇 《网络对抗》Exp8 Web基础

    20145222 黄亚奇 <网络对抗>Exp8 Web基础 实践具体要求 (1).Web前端HTML(1分) 能正常安装.启停Apache.理解HTML,理解表单,理解GET与POST方法 ...

  7. UDP协议----简单的CS模型实现

    UDP简单介绍 传输层主要应用的协议模型有两种,一种是TCP协议,另外一种则是UDP协议.TCP协议在网络通信中占主导地位,绝大多数的网络通信借助TCP协议完成数据传输.但UDP也是网络通信中不可或缺 ...

  8. Windows 10 调节缩略图背景透明度

    A goal is a dream with a deadline. Much effort, much prosperity. 用Windows 10 的朋友都知道 win10 确实挺好用,但是做的 ...

  9. Python 面向对象的三大特性:封装,继承,多态

    # 面向对象的三大特性:封装,继承,多态 # 继承的影响:资源的继承,资源的使用,资源的覆盖,资源的累加 # 资源的继承,在Python中的继承是指能使用父类的资源,而不是说在子类也复制一份父类代码到 ...

  10. VC++6.0调试简单快捷键

    编译——F7 重新编译——Ctrl+F7 设置断点 ——F9 取消断点——F9 删除所有断点——Ctrl+Shift+F9 开始调试——F5 进行下一次调试——F5 停止调试——Shift+F5 逐过 ...