首先我们要明白日常的Web网页为了保证数据的安全都会对数据的存储进行一些加密,当我需要在此网站验证时就需要对原有的密码以及账号进行加密此时我们就需要用到hashlib这个框架的一些功能,下面我就来更大家介绍一下hashlib的基本用法

hashlib只能加密不能反解,只要有足够的密码串转换成hashlib的字符串就有可能实现密码的破解

首先我们要导入hashlib包

# ### hashlib 模块
import hashlib
import random # 基本用法
# (1)创建一个md5算法的对象
hs = hashlib.md5()
# (2)把要加密的字符串通过update更新到hs这个对象当中进行运算
"""数据类型需要:二进制字节流"""
hs.update("abcdwW123^".encode("utf-8"))
# (3)返回32位16进制的字符串
res = hs.hexdigest()
print(res,type(res),len(res))

首先常用的实例化hashlib下的md5的类

其次将数据传入update这个方法中此时update里面的数据类型必须是2进制的字节流

当我把参数传入update这个方法之后我们就需要通过hs对象中的另外一个方法进行转换后的调用

hs.hexdigest()此时生成的值就是32位的字符串此时我们已经得到了初始随机的32位字符串

hashlib进阶
何为hashlib的进阶呢?在Web网站的验证中普通的hashlib加密由于密码太简单了所以在服务端会自动对客户端输入进来的密码进行字符串拼接后加密,之后再把数据库的32位字符串取出在进行对比,如果两者对比成功则代表密码验证成功
以下就是常用的hashlib进阶加密的一种操作
# 加盐 (加key => wW123#)
# 目的:是用户的密码变得复杂,不容易破解
# 参数是二进制字节流
hs = hashlib.md5("wW123#".encode())
hs.update("abcd".encode())
res = hs.hexdigest()
print(res,type(res),len(res)) # 动态加盐
res = str(random.randrange(100000,1000000))
hs = hashlib.md5(res.encode())
hs.update("abcd".encode())
res = hs.hexdigest()
print(res)
动态加盐(key)的方式需要记住的是需要在数据库保存随机的动态字符串以备下一次的密码验证时可以取到关键的的盐(key) hashlib下的sha系列
hashlib下的sha系列所具有的的功能与md5的功能是一样的但速度稍慢,安全性稍微好一点依然需要加盐(key)
以下是sha系列的基本用法
hs = hashlib.sha1()
hs.update("abcd".encode())
res = hs.hexdigest()
print(res , len(res) , type(res)) hs = hashlib.sha512()
hs.update("abcd".encode())
res = hs.hexdigest()
print(res , len(res) , type(res))

基本用法与MD5是一致的

加密扩展hmac系列

相对于hashlib系列下的MD5以及啥系列来说安全性更高,字符串更加难破解

用法为

hmac.new(key,msg)---》key即就是需要增加的盐(key),msg即是所要加密的字符串

以下是hmac的基本用法

# ### hmac
import hmac
"""
hmac 也是加密算法,相对来说,字符串更难破解
""" key = b""
msg = b"abcd"
hm = hmac.new(key,msg)
res = hm.hexdigest()
print(res,len(res)) # 动态加盐
import os
"""urandom 随机返回具有固定长度的二进制字节流 参数:字节流的长度"""
res = os.urandom(32)
print(res,len(res)) key = os.urandom(32)
msg = b"abcd"
hm = hmac.new(key,msg)
res = hm.hexdigest()
print(res)




 

hashlib以及hmac的日常应用的更多相关文章

  1. python 内置模块之hashlib、hmac、uuid

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

  2. Python hashlib and hmac

    hashlib hashlib提供了常用的摘要算法:MD5, SHA1等等 摘要算法:也成哈希算法,散列算法.通过一个函数把任意长度的数据转换成一个长度固定的数据串.主要用在存储一些不能被修改和查看的 ...

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

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

  4. hashlib(hmac)进阶之client跟server交互

    首先我还是要强调不管任何相同的字符串通过hashlib加密之后都会产生相同的32位字符串,这个是日常Web中常用的加密算法如果我的client发送一个请求过来我server接受到后就要对该密码进行判断 ...

  5. hashlib 和 hmac

    import hashlib hash = hashlib.md5([bytes('SALT_STRING', encoding='utf-8’)]) #SALT_STRING :加盐 hash.up ...

  6. hash模块 hashlib 和hmac

    hashlib模块 用于加密相关的操作,代替md5模块和sha模块,主要提供SHA1,SHA224,SSHA256,SHA384,SHA512,MD5算法 直接看代码案例: ---------md5- ...

  7. python hashlib、hmac模块

    一.hashlib模块 import hashlib m = hashlib.md5() m.update(b"Hello") print(m.hexdigest()) m.upd ...

  8. day20 hashlib、hmac、subprocess、configparser模块

    hashlib模块:加密 import hashlib# 基本使用cipher = hashlib.md5('需要加密的数据的二进制形式'.encode('utf-8'))print(cipher.h ...

  9. hashlib 和 hmac 算法的区别

    -----md5 = hashlib.md5() md5.update(password+salt) md5.hexdigest() ----- h = hmac.new(key,password,d ...

随机推荐

  1. GIL全局解释器锁、死锁、递归锁、线程队列

    目录 GIL全局解释锁 多线程的作用 测试计算密集型 IO密集型 死锁现象 递归锁 信号量(了解) 线程队列 GIL全局解释锁 GIL本质上是一个互斥锁. GIL是为了阻止同一个进程内多个进程同时执行 ...

  2. DOS(磁盘操作系统)基本命令-思维导图

  3. 2015年蓝桥杯B组C/C++决赛题解

    2015年第六届蓝桥杯B组C/C++决赛题解 点击查看2015年第六届蓝桥杯B组C/C++国赛题目(不含答案)     1.积分之迷 三重循环 枚举A,B,C的值,如果满足两个条件:3个A + 7个B ...

  4. [C9] 降维(Dimensionality Reduction)

    降维(Dimensionality Reduction) 动机一:数据压缩(Motivation I : Data Compression) 数据压缩允许我们压缩数据,从而使用较少的计算机内存或磁盘空 ...

  5. testNG xml文件详解

    网上看到一篇整理的非常详细的xml文件详解,分享一下: 1 <?xml version="1.0" encoding="UTF-8"?> 2 < ...

  6. luoguP4719 【模板】动态 DP

    题意 我理解的动态DP: 发现DP可以写成矩阵的形式,因此用数据结构维护矩阵乘积. 对于这道题,显然有DP: \(f_{x,0/1}\)表示\(x\)的子树中,x选/不选的最大点独立集. \(f_{x ...

  7. vue中keepAlive的使用

    在开发中经常有从列表跳到详情页,然后返回详情页的时候需要缓存列表页的状态(比如滚动位置信息),这个时候就需要保存状态,要缓存状态:vue里提供了keep-alive组件用来缓存状态.可以用以下几种方案 ...

  8. jenkins配置自动部署java程序

    任务背景 该项目包含4个程序包:a.jar,b.jar,c.jar,d.jar,每次启动前需要修改程序中的配置文件(修改数据源配置),然后按照先后顺序启动. 任务目标 1.利用jenkins拉取代码, ...

  9. Python调用C的DLL(动态链接库)

    开发环境:mingw64位,python3.6 64位 参考博客: mingw编译dll: https://blog.csdn.net/liyuanbhu/article/details/426123 ...

  10. 【BZOJ3876】[AHOI2014&JSOI2014] 支线剧情(无源汇有上下界网络流)

    点此看题面 大致题意: 有一张\(DAG\),经过每条边有一定时间,从\(1\)号点出发,随时可以返回\(1\)号点,求经过所有边的最短时间. 无源汇有上下界网络流 这是无源汇有上下界网络流的板子题. ...