Python hashlib模块用法实例分析


Posted in Python onJune 12, 2018

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

一、hashlib基本使用

python中的hashlib模块用来进行hash或者md5加密,而且这种加密是不可逆的,所以这种算法又被称为摘要算法。其支持Openssl库提供的所有算法,包括md5、sha1、sha224、sha256、sha512等。

常用的属性和方法:

algorithms:列出所有加密算法('md5','sha1','sha224','sha256','sha384','sha512')
digesti_size:产生的散列的字节大小
md5()/sha1():创建一个md5或者sha1加密模式的hash对象
update(arg):用字符串参数来更新hash对象,如果同一个has对象重复调用该方法,如下:m.update(a); m.update(b),则等于m.update(a+b)
digest():返回摘要,作为二进制数据字符串值
hexdigest():返回摘要,作为十六进制数据字符串值
copy():复制

下面是一个简单的加密示例:

import hashlib
m = hashlib.md5()
m.update('how to use md5'.encode('utf-8'))
m.update('in python hashlib'.encode('utf-8'))
print m.hexdigest()

返回值如下:

9f97604918a2e86bfcc4aea5c35a4c8b

下面一个示例用于计算文件md5值:

#!/usr/bin/env python
#coding: utf-8
import hashlib
import sys
def main():
  if len(sys.argv) != 2:
    sys.exit('Usage: %s file' % sys.argv[0])
  filename = sys.argv[1]
  m = hashlib.md5()
  with open(filename, 'rb') as fp:
    while True:
      blk = fp.read(4096) # 每次读取4kb
      if not blk: break
      m.update(blk)
  print m.hexdigest(), filename
if __name__ == '__main__':
  main()

二、hashlib的应用场景

摘要算法通常应用于网站存储用户的帐号密码相关信息。默认情况下,我们插入到数据库的帐号密码都是以明文保存。这样的话,一旦数据库泄露,所有用户的口令都会直接泄露,而且明文保存,网站管理员也可以直接查看到用户口令,这样及不安全。所以我们可以在获取到用户输入的密码以后,直接对其进行加密处理。然后将加密的字符串存入数据库。这样当下次用户登录时,再对用户输入的密码进行加密处理,然后与数据库中存储的加密字串进行比对,如果匹配,则说明密码正确。

当然上述方法比明文存储密码确实要安全不少。但在有些场景中,用户通常会将密码设置的尤为简单。这样如果数据库泄露,黑客可以通过简单的密码尝试来完成对加密字串的匹配。为了解决这种方法,我们通常需要对密码做“加盐”处理。如下:

def get_md5(password):
  m = hashlib.md5()
  m.update(password)
  return m.hexdigest()
def calc_md5(password):
  return get_md5(password + 'the-Salt')
db = {}
def register(username,password):
  db[username] = username
  db[password] = calc_md5(password)

这样,只要'the-Salt'部分不被泄露,就没办法反推用户的简单密码。

但是这样仍然有个问题,那就是多个用户的密码可能重复,这样,在数据库里就会出现相同的加密字串。我们知道通常而言,用户的用户名肯定不会相同。我们再假设用户的用户名不会改变。我们可以使用用户的用户名来做加盐处理,如下:

def clc_md5(username,password):
  return get_md5(passwd + username + 'the-Salt')
Python 相关文章推荐
Python中实现的RC4算法
Feb 14 Python
python optparse模块使用实例
Apr 09 Python
python中format()函数的简单使用教程
Mar 14 Python
python+pandas生成指定日期和重采样的方法
Apr 11 Python
Python socket实现的简单通信功能示例
Aug 21 Python
python训练数据时打乱训练数据与标签的两种方法小结
Nov 08 Python
python+opencv 读取文件夹下的所有图像并批量保存ROI的方法
Jan 10 Python
python输出电脑上所有的串口名的方法
Jul 02 Python
python设计tcp数据包协议类的例子
Jul 23 Python
Python3合并两个有序数组代码实例
Aug 11 Python
浅析python中的del用法
Sep 02 Python
使用Python拟合函数曲线
Apr 14 Python
python中itertools模块zip_longest函数详解
Jun 12 #Python
Python subprocess模块常见用法分析
Jun 12 #Python
python 基本数据类型占用内存空间大小的实例
Jun 12 #Python
Python中.join()和os.path.join()两个函数的用法详解
Jun 11 #Python
使用Python进行QQ批量登录的实例代码
Jun 11 #Python
python中使用psutil查看内存占用的情况
Jun 11 #Python
Python运维之获取系统CPU信息的实现方法
Jun 11 #Python
You might like
PHP执行linux命令常用函数汇总
2016/02/02 PHP
PHP二维数组矩形转置实例
2016/07/20 PHP
Thinkphp实现短信验证注册功能
2016/10/18 PHP
Laravel框架基于中间件实现禁止未登录用户访问页面功能示例
2019/01/17 PHP
PHP的PDO大对象(LOBs)
2019/01/27 PHP
比Jquery的document.ready更快的方法
2010/04/28 Javascript
js操作select控件的几种方法
2010/06/02 Javascript
javascript 基础篇3 类,回调函数,内置对象,事件处理
2012/03/14 Javascript
js日期、星座的级联显示代码
2014/01/23 Javascript
node.js中使用q.js实现api的promise化
2014/09/17 Javascript
jquery+ajax实现跨域请求的方法
2015/01/20 Javascript
JavaScript截断字符串的方法
2015/07/15 Javascript
基于Javascript实现弹出页面效果
2016/01/01 Javascript
jQuery实现的倒计时效果实例小结
2016/04/16 Javascript
JS模拟bootstrap下拉菜单效果实例
2016/06/17 Javascript
javascript 中的事件委托详解
2016/10/25 Javascript
微信小程序 wxapp视图容器 view详解
2016/10/31 Javascript
关于vuex的学习实践笔记
2017/04/05 Javascript
使用angularjs.foreach时return的问题解决
2018/09/30 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
2019/01/24 Javascript
[03:49]2016完美“圣”典风云人物:AMS专访
2016/12/06 DOTA
python自动化测试之从命令行运行测试用例with verbosity
2014/09/28 Python
Python的collections模块中的OrderedDict有序字典
2016/07/07 Python
Tensorflow 自带可视化Tensorboard使用方法(附项目代码)
2018/02/10 Python
python的pandas工具包,保存.csv文件时不要表头的实例
2018/06/14 Python
python 爬虫百度地图的信息界面的实现方法
2019/10/27 Python
使用Python制作缩放自如的圣诞老人(圣诞树)
2019/12/25 Python
完美解决keras保存好的model不能成功加载问题
2020/06/11 Python
咖啡为什么会有酸味?你喝到的咖啡為什麼是酸的?
2021/03/17 冲泡冲煮
PatPat香港:婴童服饰和亲子全家装在线购物
2020/09/27 全球购物
同事打架检讨书
2014/02/04 职场文书
《颐和园》教学反思
2014/02/26 职场文书
六五普法规划实施方案
2014/03/21 职场文书
环保志愿者活动方案
2014/08/14 职场文书
邀请函的格式
2015/01/30 职场文书
vue/cli 配置动态代理无需重启服务的方法
2022/05/20 Vue.js