需求是是要将密码存在数据库里,所以要加密解密是可逆的,在数据库里不要有特殊字符,防止数据库备份和恢复中出错。
安装PyCrypto,可以用AES和DES。我使用DES加解密。加密后将密文转为16进制,在入库。测试代码如下。
#!/bin/python #-*- coding:utf-8 -*- # Filename: # Revision: # Date: 2013-06-07 # Author: simonzhang # web: www.simonzhang.net # Email: simon-zzm@163.com ### END INIT INFO # easy_install PyCrypto from binascii import b2a_hex, a2b_hex from Crypto.Cipher import DES key = '12345678' #长度必须是8位的 text = 'simonzhang.net ' #长度必须是8的倍数,我用空格补的 # 实例化 obj = DES.new(key) # 加密 cryp = obj.encrypt(text) pass_hex = b2a_hex(cryp) print pass_hex print '=' * 20 # 解密 get_cryp = a2b_hex(pass_hex) after_text = obj.decrypt(get_cryp) print after_text
发表评论