您的位置:首页 > 编程语言 > Python开发

python AES-16位加密解密功能实现

2015-12-30 12:00 936 查看
从网上搜了很多这种python AES相关内容,但是大部分都是需要自己调试修改半天才能使用,有的甚至埋下很多坑,费时费力,我这边根据项目需求,也需要弄一套AES-16位加密和解密API

我用的python加密组件是Crypto,很好用,可以从网上下载最新的库,我用的比较稳定的版本2.6,可以从https://pypi.python.org/pypi/pycrypto下载;

通过./configure,python setup.py build ,python setup.py install 三步法完成编译安装,一定要从官方下载,我当时一开始某一个网站下载一个,经过三步法虽然安装完成了,但是调试发现aes无法使用一直coredown,最后就直接删除掉,从官方下载一个。

经过调试通过的AES接口如下:

from Crypto.Cipher import AES

from binascii import b2a_hex, a2b_hex

 

class crypt():

    def __init__(self):

        self.key = '1234567890123456'

        self.iv  = 'This is an IV456'

        self.mode = AES.MODE_CBC

        self.BS = AES.block_size

        self.pad = lambda s: s + (self.BS - len(s) % self.BS) * chr(self.BS - len(s) % self.BS)

        self.unpad = lambda s : s[0:-ord(s[-1])]

    def encrypt(self, text):

        text = self.pad(text)

        self.obj1 = AES.new(self.key, self.mode, self.iv)

        self.ciphertext = self.obj1.encrypt(text)

        return b2a_hex(self.ciphertext)

    

    def decrypt(self, text):

        self.obj2 = AES.new(self.key, self.mode, self.iv)

        plain_text  = self.obj2.decrypt(a2b_hex(text))

        return self.unpad(plain_text.rstrip('\0'))

if __name__ == '__main__':

    pc = crypt()

    e = pc.encrypt("hello")

    print e

    d = pc.decrypt(e)

    print d

该接口类主要做了加密解密中补位的操作,满足16位加密和解密要求。


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: