python进行des加密解密,而且可以与JAVA进行互相加密解密

本文介绍了一个使用Python实现DES加密解密的具体示例。该示例利用pyDes库完成CBC模式下的加密与解密过程,并展示了如何生成并打印加密后的Token。此外,还提供了获取MAC地址和时间戳的方法。
摘要由CSDN通过智能技术生成
import binascii
from pyDes import des, CBC, PAD_PKCS5
import uuid
import time

# pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pyDes
secret_key = '19771011'


# http://blog.csdn.net/lihao21/article/details/78557461?locationNum=11&fps=1
def des_encrypt(s):
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)


def des_descrypt(s):
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


def get_mac_address():
mac = uuid.UUID(int=uuid.getnode()).hex[-12:]
return ":".join([mac[e:e + 2] for e in range(0, 11, 2)]).upper()


# 获取时间戳
def get_time_stamp():
ct = time.time()
local_time = time.localtime(ct)
data_head = time.strftime("%Y-%m-%d %H:%M:%S", local_time)
data_secs = (ct - int(ct)) * 1000
time_stamp = "%s.%03d" % (data_head, data_secs)
return time_stamp


def trydecode(token):
try:
str_de = des_descrypt(token)
return True, str(str_de, encoding="utf-8")
except:
return False, '无法解密'


# 任务编号
guid = uuid.uuid3(uuid.NAMESPACE_DNS, 'dsideal')
# 时间戳
timespan = get_time_stamp().replace('-', '').replace(':', '').replace(' ', '').replace('.', '')
str_en = des_encrypt(str(guid).upper() + ' ' + get_mac_address() + ' ' + timespan + ' ')
encodestr = str(str_en, encoding="utf-8")
print('Token:' + encodestr)

# 尝试解密
b, m = trydecode(encodestr)
if b:
print(m)
else:
print('无法解密!')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值