python 实现常用的数据编码和对称加密

本贴最后更新于 799 天前,其中的信息可能已经时移世改

python实现常用的数据编码和对称加密

前言

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

1、base64编码

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

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

案例:
import base64

data= "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加密,直接使用ashlib这个库就可以实现。

案例
from hashlib import md5

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

3、DES加密

什么是对称加密?

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

1585037313195.png

什么是EDS加密?

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

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

案例:
from pyDes import des, CBC, PAD_PKCS5
import binascii

def des_encrypt(s, KEY):
    secret_key = KEY
    iv = secret_key
    k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)
    en = k.encrypt(s, padmode=PAD_PKCS5)
    return binascii.b2a_hex(en).decode()

def des_descrypt(s, KEY):
    secret_key = KEY
    iv = secret_key
    k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)
    de = k.decrypt(binascii.a2b_hex(s), padmode=PAD_PKCS5)
    return de.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这个模块去实现

案例:
import base64
import hashlib

import pyDes


def encrypt_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)
    return d.decode()


def descrypt_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)
    return d.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这个库

案例
import base64
from Crypto.Cipher import AES


class AesEncrypt:
    # 密钥
    key = '0CoJUm6Qyw8W8jud'
    # 偏移量
    vi = '0102030405060708'

    def encrypt(self, data):
        """加密"""
        data = data.encode('utf8')
        data = (lambda s: 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')
        return enctext

    def decrypt(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 = lambda s: s[0:-s[-1]]
        text_decrypted = unpad(text_decrypted)
        text_decrypted = text_decrypted.decode('utf8')
        return text_decrypted


if __name__ == '__main__':
    # 注意点:加密数据中有中文的时候,会有问题
    data = "musen123"
    aes = AesEncrypt()
    # 加密
    enctext = aes.encrypt(data)
    print(enctext)
    # # 解密
    text_decrypted = aes.decrypt(enctext)
    print(text_decrypted)

回帖
请输入回帖内容 ...