用python编写DES和AES加密

首先用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()

下面时运行代码窗口
在这里插入图片描述
运行窗口截图

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值