python 之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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#实现MD5加密
#加密之后再存储密码,这样相对安全
 
import hashlib
import shelve
 
'''
#第一种实现
def sec_md(passwd):
    hash = hashlib.md5() #创建一个MD5对象
    hash.update(passwd) #用update方法,使其通过md5方式加密
    return hash.hexdigest()
 
#第二种实现方式,跟上面最大的不同就是加密后长度的不同
def sec_ps(passwd):
    hash = hashlib.md5() #创建一个MD5对象
    hash.update(passwd) #用update方法,使其通过md5方式加密
    return hash.digest()
注:
MD5是不能够反解,用户如果想判断密码是否匹配,把输入的密码再以
同样的方式进行加密后,再与存储在数据库加密的值进行匹配。所以,不能反
解,那么匹配的时候就得正解,通过匹配密文的方式进行匹配
'''
 
#小栗子
def sec_md(passwd):
    hash = hashlib.md5()
    hash.update(passwd) 
    return hash.hexdigest()
         
def adduser(name,passwd):
    = shelve.open('data.db')
    password = sec_md(passwd)
    f[name] = password
    f.close()
         
    #添加一个用户
    #adduser('tantianran','1qaz#EDC')
     
def login(name,passwd):
    password = sec_md(passwd)
    data = shelve.open('data.db')
    if password == data.get(name,None):
        return True
    else:
        return False
 
if __name__ == "__main__":
    username = raw_input('用户名:')
    password = raw_input('登录口令:')
 
    while True:
        if login(username,password) == True:
            print '登录成功'
            break
        else:
            print '登录失败'        
            break




本文转自 TtrToby 51CTO博客,原文链接:http://blog.51cto.com/freshair/1870840
上一篇:[Docker系列·12] 搭建Kafka服务器


下一篇:7个改变世界的Java项目