首先用pip安装模块
这是一个带有GUI窗口的程序
from tkinter import *
from Crypto.Cipher import AES, DES
class CryptoApp:
def __init__(self, master):
self.master = master
master.title("加密/解密工具")
# 标签和输入框
self.label1 = Label(master, text="输入要加密/解密的字符串:")
self.label1.pack()
self.input_text = Text(master, height=5, width=50)
self.input_text.pack()
self.label2 = Label(master, text="输入秘钥:")
self.label2.pack()
self.key_entry = Entry(master)
self.key_entry.pack()
# 加密前后文本框
self.label3 = Label(master, text="加密前/解密后:")
self.label3.pack()
self.result_text = Text(master, height=5, width=50)
self.result_text.pack()
# 按钮
self.encrypt_button = Button(master, text="AES加密", command=self.encrypt_aes)
self.encrypt_button.pack(side=LEFT)
self.decrypt_button = Button(master, text="AES解密", command=self.decrypt_aes)
self.decrypt_button.pack(side=LEFT)
self.encrypt_button = Button(master, text="DES加密", command=self.encrypt_des)
self.encrypt_button.pack(side=LEFT)
self.decrypt_button = Button(master, text="DES解密", command=self.decrypt_des)
self.decrypt_button.pack(side=LEFT)
def get_input_text(self):
return str(self.input_text.get("1.0", END))
def get_key(self):
key = bytes(self.key_entry.get().ljust(16), 'utf-8')
return key
def encrypt_aes(self):
key = self.get_key()
cipher = AES.new(key, AES.MODE_EAX)
nonce = cipher.nonce
plaintext = bytes(self.get_input_text(), 'utf-8')
ciphertext, tag = cipher.encrypt_and_digest(plaintext)
self.result_text.delete("1.0", END)
self.result_text.insert(END, "加密前: " + str(plaintext) + "\n\n")
self.result_text.insert(END, "加密后: " + str(ciphertext))
self.input_text.delete("1.0", END)
def decrypt_aes(self):
key = self.get_key()
ciphertext = bytes(self.get_input_text(), 'utf-8')
cipher = AES.new(key, AES.MODE_EAX, nonce=ciphertext[:16])
plaintext = cipher.decrypt(ciphertext[16:])
self.result_text.delete("1.0", END)
self.result_text.insert(END, "解密前: " + str(ciphertext) + "\n\n")
self.result_text.insert(END, "解密后: " + str(plaintext))
self.input_text.delete("1.0", END)
def encrypt_des(self):
key = self.get_key()
cipher = DES.new(key, DES.MODE_ECB)
plaintext = bytes(self.get_input_text(), 'utf-8')
ciphertext = cipher.encrypt(plaintext)
self.result_text.delete("1.0", END)
self.result_text.insert(END, "加密前: " + str(plaintext) + "\n\n")
self.result_text.insert(END, "加密后: " + str(ciphertext))
self.input_text.delete("1.0", END)
def decrypt_des(self):
key = self.get_key()
cipher = DES.new(key, DES.MODE_ECB)
ciphertext = bytes(self.get_input_text(), 'utf-8')
plaintext = cipher.decrypt(ciphertext)
self.result_text.delete("1.0", END)
self.result_text.insert(END, "解密前: " + str(ciphertext) + "\n\n")
self.result_text.insert(END, "解密后: " + str(plaintext))
self.input_text.delete("1.0", END)
root = Tk()
app = CryptoApp(root)
root.mainloop()
下面时运行代码窗口
运行窗口截图