list1234 发表于 2018-8-16 10:55:38

python 之MD5加密

#!/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):
  
    f = shelve.open('data.db')
  
    password = sec_md(passwd)
  
    f = 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


页: [1]
查看完整版本: python 之MD5加密