hashlib以及hmac的日常应用
首先我们要明白日常的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的日常应用的更多相关文章
- python 内置模块之hashlib、hmac、uuid
一.hashlib md5和sha算法通过消息摘要算法生成定长的消息摘要,消息摘要算法是不可逆的.但同一段消息通过摘要算法后得到的值是一样的,可一通过比对消息摘要验证数据的完整性. sha算法比MD5 ...
- Python hashlib and hmac
hashlib hashlib提供了常用的摘要算法:MD5, SHA1等等 摘要算法:也成哈希算法,散列算法.通过一个函数把任意长度的数据转换成一个长度固定的数据串.主要用在存储一些不能被修改和查看的 ...
- Python之数据加密与解密及相关操作(hashlib、hmac、random、base64、pycrypto)
本文内容 数据加密概述 Python中实现数据加密的模块简介 hashlib与hmac模块介绍 random与secrets模块介绍 base64模块介绍 pycrypto模块介绍 总结 参考文档 提 ...
- hashlib(hmac)进阶之client跟server交互
首先我还是要强调不管任何相同的字符串通过hashlib加密之后都会产生相同的32位字符串,这个是日常Web中常用的加密算法如果我的client发送一个请求过来我server接受到后就要对该密码进行判断 ...
- hashlib 和 hmac
import hashlib hash = hashlib.md5([bytes('SALT_STRING', encoding='utf-8’)]) #SALT_STRING :加盐 hash.up ...
- hash模块 hashlib 和hmac
hashlib模块 用于加密相关的操作,代替md5模块和sha模块,主要提供SHA1,SHA224,SSHA256,SHA384,SHA512,MD5算法 直接看代码案例: ---------md5- ...
- python hashlib、hmac模块
一.hashlib模块 import hashlib m = hashlib.md5() m.update(b"Hello") print(m.hexdigest()) m.upd ...
- day20 hashlib、hmac、subprocess、configparser模块
hashlib模块:加密 import hashlib# 基本使用cipher = hashlib.md5('需要加密的数据的二进制形式'.encode('utf-8'))print(cipher.h ...
- hashlib 和 hmac 算法的区别
-----md5 = hashlib.md5() md5.update(password+salt) md5.hexdigest() ----- h = hmac.new(key,password,d ...
随机推荐
- [Go] tcp服务下的数据传递
go中实现一个tcp服务,首先是要监听端口,接收请求,这个地方会被阻塞等待当客户端连接过来,会开一个grountine去处理这条客户端的tcp连接,因此可以同时处理多条连接 在连接中,要循环的去读取客 ...
- C++ 基础语法 快速复习笔记(1)
最近要刷题,重温一下C++基本的概念...233 1.概念: C++ 是一种静态类型的.编译式的.通用的.大小写敏感的.不规则的编程语言,支持过程化编程.面向对象编程和泛型编程. C++ 被认为是一种 ...
- 28.Java基础_抽象类
抽象类的成员特点 public abstract class Animal { private String name; private int age; public Animal() { } pu ...
- java程序:调用百度api进行情感分析
源码: package com.jeson.ceshi; import java.util.HashMap; import org.json.JSONObject; import com.baidu. ...
- angular 运行报错
angular 运行时报错ERROR in node_modules/rxjs/internal/types.d.ts(81,44): error TS1005: ';' expected. node ...
- vue.js操作元素属性
vue动态操作div的class 看代码: <!doctype html> <html lang="en"> <head> <meta c ...
- 第04组 Alpha事后诸葛亮
一.组长博客:地址 二.Postmortem模板 设想和目标 1.我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们要解决的问题是让大学生可以通过福鱼网站将暂时无 ...
- vscode配置python环境-运行调试-windows环境
官方文件介绍 https://code.visualstudio.com/docs/languages/python 准备: vscode下载安装 python3版本下载(安装时可以选择添加环境变量, ...
- QList去掉重复项 .toSet()报错???
我们知道QList::toSet()函数可以将QList转成QSet.可我却遇到报错: QList<QVariant> datas = it.value().values(); QSet& ...
- 1+X证书Web前端开发规范手册
一.规范目的 1.1 概述 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档. 本规范文档一经确认, 前端开发人员必须按本文档规范进行前台页面开发. 本 ...