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监控网站运行异常并发送邮件的方法
Mar 13 Python
python3.5实现socket通讯示例(TCP)
Feb 07 Python
Unicode和Python的中文处理
Mar 19 Python
django模板语法学习之include示例详解
Dec 17 Python
python抓取网页中链接的静态图片
Jan 29 Python
[原创]windows下Anaconda的安装与配置正解(Anaconda入门教程)
Apr 05 Python
python使用ddt过程中遇到的问题及解决方案【推荐】
Oct 29 Python
Django之PopUp的具体实现方法
Aug 31 Python
Python 闭包,函数分隔作用域,nonlocal声明非局部变量操作示例
Oct 14 Python
python zip()函数使用方法解析
Oct 31 Python
Python底层封装实现方法详解
Jan 22 Python
Python模块zipfile原理及使用方法详解
Aug 04 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 缓冲的免费实现方法
2006/10/09 PHP
PHP mkdir()无写权限的问题解决方法
2014/06/19 PHP
thinkphp中字符截取函数msubstr()用法分析
2016/01/09 PHP
PHP中使用jQuery+Ajax实现分页查询多功能操作(示例讲解)
2017/09/17 PHP
php+Ajax无刷新验证用户名操作实例详解
2019/03/04 PHP
做网页的一些技巧
2007/02/01 Javascript
jQuery实现用户注册的表单验证示例
2013/08/28 Javascript
javascript查找字符串中出现最多的字符和次数的小例子
2013/10/29 Javascript
JavaScript计时器示例分析
2015/02/05 Javascript
javascript动态创建表格及添加数据实例详解
2015/05/13 Javascript
AngularJS 作用域详解及示例代码
2016/08/17 Javascript
Node.js通过身份证号验证年龄、出生日期与性别方法示例
2017/03/09 Javascript
react build 后打包发布总结
2018/08/24 Javascript
vue.js父子组件通信动态绑定的实例
2018/09/28 Javascript
Vue.js 中 axios 跨域访问错误问题及解决方法
2018/11/21 Javascript
React Native 混合开发多入口加载方式详解
2019/09/23 Javascript
有关vue 开发钉钉 H5 微应用 dd.ready() 不执行问题及快速解决方案
2020/05/09 Javascript
vue实现简单全选和反选功能
2020/09/15 Javascript
[03:49]DOTA2英雄基础教程 光之守卫
2014/01/14 DOTA
Python输出\u编码将其转换成中文的实例
2018/12/15 Python
用Python实现最速下降法求极值的方法
2019/07/10 Python
pygame实现俄罗斯方块游戏(基础篇2)
2019/10/29 Python
django 简单实现登录验证给你
2019/11/06 Python
python调用私有属性的方法总结
2020/07/24 Python
Python 如何测试文件是否存在
2020/07/31 Python
Python中的特殊方法以及应用详解
2020/09/20 Python
公司行政经理岗位职责
2013/12/24 职场文书
岗位职责风险点
2014/03/12 职场文书
新员工试用期自我鉴定
2014/04/17 职场文书
司法助理专业自荐书
2014/06/13 职场文书
《爱的教育》读书心得
2014/11/08 职场文书
证劵公司反洗钱宣传活动总结
2015/05/08 职场文书
2015年数学教研组工作总结
2015/05/23 职场文书
《童年的发现》教学反思
2016/02/18 职场文书
详解GaussDB for MySQL性能优化
2021/05/18 MySQL
MySQL系列之九 mysql查询缓存及索引
2021/07/02 MySQL