原文地址:http://www.cnblogs.com/xiaobeibei26/p/6422012.html
Python里面的hashlib模块提供了很多加密的算法,这里介绍一下hashlib的简单使用事例,用hashlib的md5算法加密数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
import
hashlib
hash
=
hashlib.md5()
#md5对象,md5不能反解,但是加密是固定的,就是关系是一一对应,所以有缺陷,可以被对撞出来
hash
.update(bytes(
'admin'
,encoding
=
'utf-8'
))
#要对哪个字符串进行加密,就放这里
print
(
hash
.hexdigest())
#拿到加密字符串
# hash2=hashlib.sha384()#不同算法,hashlib很多加密算法
# hash2.update(bytes('admin',encoding='utf-8'))
# print(hash.hexdigest())
hash3
=
hashlib.md5(bytes(
'abd'
,encoding
=
'utf-8'
))
''' 如果没有参数,所以md5遵守一个规则,生成同一个对应关系,如果加了参数,
就是在原先加密的基础上再加密一层,这样的话参数只有自己知道,防止被撞库,
因为别人永远拿不到这个参数
'''
hash3.update(bytes(
'admin'
,encoding
=
'utf-8'
))
print
(hash3.hexdigest())
|
如图为执行结果
这里写一个利用md5进行用户登陆网站进行注册之后密码加密的基本事例,加深理解
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
29
30
31
|
#hashlib简单使用
def
md5(arg):
#这是加密函数,将传进来的函数加密
md5_pwd
=
hashlib.md5(bytes(
'abd'
,encoding
=
'utf-8'
))
md5_pwd.update(bytes(arg,encoding
=
'utf-8'
))
return
md5_pwd.hexdigest()
#返回加密的数据
def
log(user,pwd):
#登陆时候时候的函数,由于md5不能反解,因此登陆的时候用正解
with
open
(
'db'
,
'r'
,encoding
=
'utf-8'
) as f:
for
line
in
f:
u,p
=
line.strip().split(
'|'
)
if
u
=
=
user
and
p
=
=
md5(pwd):
#登陆的时候验证用户名以及加密的密码跟之前保存的是否一样
return
True
def
register(user,pwd):
#注册的时候把用户名和加密的密码写进文件,保存起来
with
open
(
'db'
,
'a'
,encoding
=
'utf-8'
) as f:
temp
=
user
+
'|'
+
md5(pwd)
f.write(temp)
i
=
input
(
'1表示登陆,2表示注册:'
)
if
i
=
=
'2'
:
user
=
input
(
'用户名:'
)
pwd
=
input
(
'密码:'
)
register(user,pwd)
elif
i
=
=
'1'
:
user
=
user
=
input
(
'用户名:'
)
pwd
=
input
(
'密码:'
)
r
=
log(user,pwd)
#验证用户名和密码
if
r
=
=
True
:
print
(
'登陆成功'
)
else
:
print
(
'登陆失败'
)
else
:
print
(
'账号不存在'
)
|
这里只简单写了一个用户的注册以及登陆