(一)hashlib:密码散列
1.散列算法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
import
hashlib
‘‘‘
由于hashlib有OpenSSL提供底层支持,所以OpenSSL库提供的所有算法都可以用,
比如:md5,sha1,sha224,sha256,sha384,sha512
有些算法在所有平台上都可以用,有些则依赖于底层库。这两类算法分别由algorithms_guaranteed和algorithms_available提供
‘‘‘
‘‘‘
blake2b,blake2s,md5,sha3_224,sha3_256,sha3_384,sha3_512,sha512,shake_128,shake_256
‘‘‘
print
(
","
.join(
sorted
(hashlib.algorithms_available)))
‘‘‘
0,SHA1,SHA224,SHA256,SHA384,SHA512,blake2b,blake2b512,blake2s256,md4,md5-sha1,mdc2,ripemd160,shake_256,whirlpool
‘‘‘
|
2.md5示例
3.sha1示例
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import
hashlib
‘‘‘
虽然加密方式不一样,但是api都是一样的
‘‘‘
# 创建一个sha1散列对象
m
=
hashlib.sha1()
# 传入二进制数据
data
=
"从前有座山"
.encode(
"utf-8"
)
m.update(data)
# 获取加密后的值,digest是二进制,hexdigest则是十六进制
print
(m.digest())
# b‘A\xe6\x19\x8d\xca\xa9vV\xaf)\xf9\x9a\x91\xaf \x8d\x18PS\xcf‘
print
(m.hexdigest())
# 41e6198dcaa97656af29f99a91af208d185053cf
|
4.按名创建散列
5.增量更新
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
import
hashlib
‘‘‘
‘‘‘
data
=
"abcde"
m
=
hashlib.md5()
m.update(data.encode(
"utf-8"
))
print
(m.hexdigest())
# ab56b4d92b40713acc5af89985d4b786
m2
=
hashlib.md5()
m2.update(
"从"
.encode(
"utf-8"
))
m2.update(
"前"
.encode(
"utf-8"
))
m2.update(
"有"
.encode(
"utf-8"
))
m2.update(
"座"
.encode(
"utf-8"
))
m2.update(
"山"
.encode(
"utf-8"
))
print
(m.hexdigest())
# ab56b4d92b40713acc5af89985d4b786
|
(二)hmac:密码消息签名与验证
1.消息签名
2.候选摘要类型
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
import
hmac
‘‘‘
一般认为sha1算法更健壮,更建议使用
‘‘‘
digest_maker
=
hmac.new(
"秘密秘钥"
.encode(
"utf-8"
),b"
","
sha1")
# 默认使用md5
digest_maker.update(b
"aaaaaa"
)
print
(digest_maker.hexdigest())
# ed4138f1e4b9dccb616d04750d45c85d6c5bc95c
‘‘‘
‘‘‘
|
(三)secrets
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
import
secrets
# secrets貌似是python3.6里新增的模块,先来看看api
# secrets.randbits(k),返回带有k个随机位的整数
# secrets.compare_digest(a,b),比较两个字符串是否相等
print
(secrets.choice(
"古明地盆"
))
# 古
print
(secrets.choice([
"satori"
,
"mashiro"
,
"nagisa"
]))
# nagisa
# 和random.choice()是类似的
print
(secrets.randbelow(
8
))
# 6
# 和random.randint()类似,但是secrets.randbelow()只能默认从零开始,且不包含右端点
print
(secrets.randbits(
7
))
# 96
print
(secrets.token_bytes())
# b‘\x87\x98\x1c\x80TO\xcf\x82\xc9\xf1\xd6\xf6f\xd7\xd7\xae\xea.\xfd0y\xd6\xaf\xfbe\xb4v\[email protected]\xc8t\xe6‘
print
(secrets.token_bytes(nbytes
=
20
))
# b‘\xa5:(\xf2\xcb\xb2\xd8\xbce\xacn\x8c\x95\x05:\x07e#\xa7M‘
print
(secrets.token_hex())
# 0904e492deaab1270f11671d687f3bb2c7ead5283bfe55a3b51e560101c38828
print
(secrets.token_hex(
20
))
# 851801ed1367bc946b1f28812a83a7e84d91908e
print
(secrets.token_urlsafe())
# sGGhrL8VLECMYalQ5DHMDm0yugoVsr2M-SvN4z2Qk8k
|
(四)base64
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
import
base64
s
=
bytes(
"古明地盆"
,encoding
=
"utf-8"
)
en_data1
=
base64.b64encode(s)
print
(en_data1)
# b‘5Y+k5piO5Zyw55uG‘
de_data1
=
base64.b64decode(en_data1)
print
(
str
(de_data1,encoding
=
"utf-8"
))
# 古明地盆
# 可以看出来,是为了考虑url安全的一种加密方式
# 与普通的b64encode不同的是,会将一些字符进行一个替换
en_data2
=
base64.urlsafe_b64encode(s)
print
(en_data2)
# b‘5Y-k5piO5Zyw55uG‘
de_data2
=
base64.urlsafe_b64decode(en_data2)
print
(
str
(de_data2,encoding
=
"utf-8"
))
# 古明地盆
|
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。