还不会python 实现常用的数据编码和对称加密?看这篇文章就够啦~

相信很多使用 python 的小伙伴在工作中都遇到过,对数据进行相关编码或加密的需求,今天这篇文章主要给大家介绍对于一些常用的数据编码和数据加密的方式,如何使用 python 去实现。话不多说,接下来直接进入主题:

1、base64 编码

什么是 Base64 编码?

Base64 就是一种基于 64 个可打印字符来表示二进制数据的方法

在 python 中对数据进行 base64 编码可以使用 base64 这个官方库

案例:

import base64data="musen"# base编码data = data.encode()res = base64.b64encode(data)print(res)# base64解码res2 = base64.b64decode(res)print(res2)


2、常见的哈希算法:


hash算法有很多:比如MD4、MD5、SHA-1 , SHA-224, SHA-256, SHA-384 和 SHA-5等等。其中MD5是比较常见的一种,也称之为MD5加密。

什么是 MD5 加密?

MD5(Message Digest Algorithm 5),是一种哈希算法,是不可逆的,即通过 md5 加密之后没办法得到原文,没有解密算法

python 中有一个叫做 hashlib 的官方库,对于一些常见的哈希算法这个库都实现了,咱们在工作中如果要使用 MD5 加密,直接使用 hashlib 这个库就可以实现。

案例

fromhashlibimportmd5defencrypt_md5(data):"""md5加密"""# 创建md5对象new_md5 = md5()    new_md5.update(data.encode('utf-8'))    res = new_md5.hexdigest()# 加密returnres


3、DES 加密

什么是对称加密?

对称加密指的的加密和解密用同一个秘钥进行加解密的加密方式。





什么是 EDS 加密?

des 对称加密,是一种比较传统的加密方式,其加密运算、解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时 , 必须共同持相同的密码。

在 python 中有一个叫做 pyDes 的第三方库可以用来实现 DES 加密,使用之前需要先通过 pip 命令安装:pip install pyDes

案例:

frompyDes import des, CBC, PAD_PKCS5importbinasciidefdes_encrypt(s, KEY):secret_key=KEYiv=secret_keyk=des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)en=k.encrypt(s, padmode=PAD_PKCS5)returnbinascii.b2a_hex(en).decode()defdes_descrypt(s, KEY):secret_key=KEYiv=secret_keyk=des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)de=k.decrypt(binascii.a2b_hex(s), padmode=PAD_PKCS5)returnde.decode()if__name__ == '__main__':    # 秘钥KEY='mHAxsLtt'    # 加密res=des_encrypt("python666", KEY)print(res)  # 解密res2=des_descrypt(res, KEY)print(res2)


4、3DES 加密

什么是 3DES 加密?

3DES(或称为 Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块应用三次 DES 加密算法

python 中实现 3DES 加密可以使用,pyDes 这个模块去实现

案例:

importbase64importhashlibimportpyDesdefencrypt_3des(data):key="U8NjHq1ZP10="hash_md5=hashlib.md5()hash_md5.update(key.encode(encoding='UTF-8'))key=hash_md5.hexdigest()iv=key[0:8]key2=key[0:24]k=pyDes.triple_des(key2, pyDes.CBC, IV=iv, pad=None, padmode=pyDes.PAD_PKCS5)d=k.encrypt(data.encode())d=base64.b64encode(d)returnd.decode()defdescrypt_3des(data):key="U8NjHq1ZP10="hash_md5=hashlib.md5()hash_md5.update(key.encode(encoding='UTF-8'))key=hash_md5.hexdigest()iv=key[0:8]key2=key[0:24]k=pyDes.triple_des(key2, pyDes.CBC, IV=iv, pad=None, padmode=pyDes.PAD_PKCS5)data=base64.b64decode(data)d=k.decrypt(data)returnd.decode()if__name__ == '__main__':res=encrypt_3des('lemonban')print(res)res2=descrypt_3des(res)print(res2)

5、AES 加密

什么是 AES 加密?

AES 也是一种对称加密。它是用来替代之前的 DES 的,安全性更高。目前已经被多方分析且广为全世界所使用,并在 2002 年 5 月 26 日成为有效的标准 ,

关于 python 中实现 Aes 加密的库很多,大家可以去 pypi 上自行下载安装,下面案例用的是 Crypto 这个库

案例

importbase64fromCrypto.CipherimportAESclassAesEncrypt:# 密钥key ='0CoJUm6Qyw8W8jud'# 偏移量vi ='0102030405060708'defencrypt(self, data):"""加密"""data = data.encode('utf8')        data = (lambdas: s + (16- len(s) %16) * chr(16- len(s) %16).encode('utf-8'))(data)        cipher = AES.new(self.key.encode('utf8'), AES.MODE_CBC, self.vi.encode('utf8'))        encryptedbytes = cipher.encrypt(data)        encodestrs = base64.b64encode(encryptedbytes)        enctext = encodestrs.decode('utf8')returnenctextdefdecrypt(self, data):"""解密"""data = data.encode('utf8')        encodebytes = base64.decodebytes(data)        cipher = AES.new(self.key.encode('utf8'), AES.MODE_CBC, self.vi.encode('utf8'))        text_decrypted = cipher.decrypt(encodebytes)        unpad =lambdas: s[0:-s[-1]]        text_decrypted = unpad(text_decrypted)        text_decrypted = text_decrypted.decode('utf8')returntext_decryptedif__name__ =='__main__':# 注意点:加密数据中有中文的时候,会有问题data ="musen123"aes = AesEncrypt()# 加密enctext = aes.encrypt(data)    print(enctext)# # 解密text_decrypted = aes.decrypt(enctext)    print(text_decrypted)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,525评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,203评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,862评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,728评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,743评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,590评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,330评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,244评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,693评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,885评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,001评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,723评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,343评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,919评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,042评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,191评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,955评论 2 355

推荐阅读更多精彩内容