查看: 1668|回复: 0

利用Python如何生成hash值示例详解

[复制链接]

665

主题

1234

帖子

6670

积分

xdtech

Rank: 5Rank: 5

积分
6670
发表于 2020-12-23 11:42:50 | 显示全部楼层 |阅读模式

一、介绍

如果在Python中需要对用户输入的密码或者其他内容进行加密,首选的方法是生成hash值。

在Python中可以利用二个模块来进行:

      - crypt

      - hashlib

二、crypt

(一)crypt的主要方法和常量


名称
描述

md5(…)
利用md5算法加密

sha1(…)
利用sha1算法加密

sha224(…)
利用sha224算法加密

sha256(…)
利用sha256算法加密

sha384(…)
利用sha384算法加密

sha512(…)
利用sha512算法加密

(二)使用说明与示例

使用crypt.crypt(…)进行hash加密的时候,需要提供二个参数:

     - 加密内容

     - salt

如果不特别指定salt,系统就会调用crypt.mksalt(…)生成一个salt

如果想要以特定的加密算法生成salt就应该使用下面的命令:

[size=1em]
[size=1em]1

[size=1em]2

[size=1em]3

[size=1em][size=1em]>>>salt = crypt.mksalt(crypt.METHOD_SHA512)
[size=1em]>>> salt
[size=1em]'$6$s8Q3eNP6urKZb3AK'




然后再进行数据加密:

[size=1em]
[size=1em]1

[size=1em]2

[size=1em]3

[size=1em][size=1em]>>> hash = crypt.crypt("helloworld",salt)
[size=1em]>>> hash
[size=1em]'$6$s8Q3eNP6urKZb3AK$L0O5cqHRU.1f170bV2KrjF3LkLL54So442TqUIsk.wYtCtOSD4Tyt./fj6W6Y.EzrbNm00grA4yPPhXGya2ie1'




三、hashlib

(一)hashlib的主要方法和常量


名称
描述

md5(…)
利用md5算法加密

sha1(…)
利用sha1算法加密

sha224(…)
利用sha224算法加密

sha256(…)
利用sha256算法加密

sha384(…)
利用sha384算法加密

sha512(…)
利用sha512算法加密

**(二)Hash对象特有的方法

如果你利用 hashlib 生成了一个Hash对象,那么这个Hash对象会包含如下方法:


名称
描述

update(arg)
可以重复利用指定了特殊加密算法的Hash对象,对 arg 进行加密

digest(…)
以字符形式返回加密内容

hexdigest(…)
以16进制形式返回加密内容

copy(…)
为了达到重复利用Hash对象的目的,而克隆Hash对象

(三)示例

1、直接使用hashlib方法

[size=1em]
[size=1em]1

[size=1em]2

[size=1em]3

[size=1em]4

[size=1em][size=1em]>>> hashlib.sha224("Nobody inspects the spammish repetition")
[size=1em]<sha224 HASH object @ 0x7f99432c5b28>
[size=1em]>>> hashlib.sha224("Nobody inspects the spammish repetition").hexdigest()
[size=1em]'a4337bc45a8fc544c03f52dc550cd6e1e87021bc896588bd79e901e2'




2、直接使用Hash对象中的方法

[size=1em]
[size=1em]1

[size=1em]2

[size=1em]3

[size=1em]4

[size=1em]5

[size=1em]6

[size=1em]7

[size=1em]8

[size=1em]9

[size=1em]10

[size=1em]11

[size=1em][size=1em]>>> m = hashlib.md5()
[size=1em]>>> m
[size=1em]<md5 HASH object @ 0x7f99432c5468>
[size=1em]>>> m.update("Nobody inspects")
[size=1em]>>> m.digest()
[size=1em]'>\xf7)\xcc\xf0\xccV\x07\x9c\xa5F\xd5\x80\x83\xdc\x12'
[size=1em]>>> m.update(" the spammish repetition")
[size=1em]>>> m.digest()
[size=1em]'\xbbd\x9c\x83\xdd\x1e\xa5\xc9\xd9\xde\xc9\xa1\x8d\xf0\xff\xe9'
[size=1em]>>> m.hexdigest()
[size=1em]'bb649c83dd1ea5c9d9dec9a18df0ffe9'




我是如何 Python 一句话校验软件哈希值的

MD5

[size=1em]
[size=1em]1

[size=1em][size=1em]python -c "import hashlib,sys;print hashlib.md5(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe




校验 下载软件是否被“中间人动过手脚”

例如:校验shadowsocks

SHA-1

[size=1em]
[size=1em]1

[size=1em][size=1em]python -c "import hashlib,sys;print hashlib.sha1(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe




SHA-256

[size=1em]
[size=1em]1

[size=1em][size=1em]python -c "import hashlib,sys;print hashlib.sha256(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe




SHA-512

[size=1em]
[size=1em]1

[size=1em][size=1em]python -c "import hashlib,sys;print hashlib.sha512(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe




总结

以上就是这篇文章的全部内容了


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表