本文实例讲述了Python实现对字符串的加密解密方法。分享给大家供大家参考,具体如下:
需求是是要将密码存在数据库里,所以要加密解密是可逆的,在数据库里不要有特殊字符,防止数据库备份和恢复中出错。
安装PyCrypto
,可以用AES和DES。我使用DES加解密。加密后将密文转为16进制,在入库。测试代码如下。
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
|
; html - script: false ] #!/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
|
希望本文所述对大家Python程序设计有所帮助。