RSA密钥生成、加解密代码

背景介绍

在这里插入图片描述

RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的。1987年首次公布,当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏开头字母拼在一起组成的。RSA是目前最有影响力的公钥加密算法,它能够抵抗到目前为止已知的绝大多数密码攻击,已被ISO推荐为公钥数据加密标准。今天只有短的RSA钥匙才可能被强力方式解破。到2008年为止,世界上还没有任何可靠的攻击RSA算法的方式。只要其钥匙的长度足够长,用RSA加密的信息实际上是不能被解破的。

RSA算法基于一个十分简单的数论事实:将两个大质数相乘十分容易,但是想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥。

由于学校作业的契机,写一一个关于RSA密钥生成、加解密的小代码,分享给大家一同学习。

其中运用了GUI交互库tkinter,这也是我第一次使用,感觉很有意思。希望在以后的日子里可以熟练掌握这个基本python库!

代码分享

import tkinter as tk
import math
from tkinter import messagebox
import random

class RSAApp:#构造函数,初始化
    def __init__(self, root):
        self.root = root
        self.root.title("RSA 加解密")
        self.main_menu()

    def main_menu(self):#主菜单
        self.clear_frame()
        tk.Label(self.root, text="主菜单").pack(pady=10)
        tk.Button(self.root, text="加密", command=self.encrypt_menu).pack(pady=5)
        tk.Button(self.root, text="解密", command=self.decrypt_menu).pack(pady=5)
        tk.Button(self.root, text="生成密钥", command=self.generate_keys_menu).pack(pady=5)

    def encrypt_menu(self):
        self.clear_frame()
        tk.Label(self.root, text="输入明文").pack(pady=5)
        self.plaintext_entry = tk.Entry(self.root, width=50)
        self.plaintext_entry.pack(pady=5)
        tk.Label(self.root, text="输入公钥 (e, n)").pack(pady=5)
        self.public_key_entry = tk.Entry(self.root, width=50)
        self.public_key_entry.pack(pady=5)
        tk.Button(self.root, text="加密", command=self.encrypt).pack(pady=5)
        tk.Button(self.root, text="返回", command=self.main_menu).pack(pady=5)

    def decrypt_menu(self):
        self.clear_frame()
        tk.Label(self.root, text="输入密文").pack(pady=5)
        self.ciphertext_entry = tk.Entry(self.root, width=50)
        self.ciphertext_entry.pack(pady=5)
        tk.Label(self.root, text="输入私钥 (d, n)").pack(pady=5)
        self.private_key_entry = tk.Entry(self.root, width=50)
        self.private_key_entry.pack(pady=5)
        tk.Button(self.root, text="解密", command=self.decrypt).pack(pady=5)
        tk.Button(self.root, text="返回", command=self.main_menu).pack(pady=5)

    def generate_keys_menu(self):
        self.clear_frame()
        tk.Label(self.root, text="生成的密钥对").pack(pady=5)
        tk.Label(self.root, text="公钥 (e, n)").pack(pady=5)
        self.public_key_text = tk.Text(self.root, height=5, width=50)
        self.public_key_text.pack(pady=5)
        tk.Label(self.root, text="私钥 (d, n)").pack(pady=5)
        self.private_key_text = tk.Text(self.root, height=5, width=50)
        self.private_key_text.pack(pady=5)
        tk.Button(self.root, text="生成密钥", command=self.generate_keys).pack(pady=5)
        tk.Button(self.root, text="返回", command=self.main_menu).pack(pady=5)

    def encrypt(self):
        try:
            plaintext = int(self.plaintext_entry.get())
            e, n = map(int, self.public_key_entry.get().split(','))
            ciphertext = pow(plaintext, e, n)
            messagebox.showinfo("加密结果", f"密文: {ciphertext}")
        except Exception as e:
            messagebox.showerror("错误", str(e))

    def decrypt(self):
        try:
            ciphertext = int(self.ciphertext_entry.get())
            d, n = map(int, self.private_key_entry.get().split(','))
            plaintext = pow(ciphertext, d, n)
            messagebox.showinfo("解密结果", f"明文: {plaintext}")
        except Exception as e:
            messagebox.showerror("错误", str(e))

    def generate_keys(self):
        p = self.generate_prime()#生成素数
        q = self.generate_prime()
        n = p * q
        phi = (p - 1) * (q - 1)
        e=random.choice([65557,65587,65609,65617,65629,65647,65651,65657,65677,65687,65701,65707,65713,65717,65719,65729,65731,65761,65777,65789])                  #公钥指数
        d = self.modinv(e, phi)
        self.public_key_text.delete(1.0, tk.END)
        self.private_key_text.delete(1.0, tk.END)
        self.public_key_text.insert(tk.END, f"{e}, {n}")
        self.private_key_text.insert(tk.END, f"{d}, {n}")

    def generate_prime(self):
        while True:
            num = random.randint(100, 999)
            if self.is_prime(num):
                return num

    def is_prime(self, num):
        if num < 2:
            return False
        for i in range(2, int(num ** 0.5) + 1):
            if num % i == 0:
                return False
        return True

    def modinv(self, a, m):
        # 扩展欧几里得算法求模逆
        m0, x0, x1 = m, 0, 1
        if m == 1:
            return 0
        while a > 1:
            q = a // m
            m, a = a % m, m
            x0, x1 = x1 - q * x0, x0
        if x1 < 0:
            x1 += m0
        return x1

    def clear_frame(self):
        for widget in self.root.winfo_children():
            widget.destroy()

if __name__ == "__main__":
    root = tk.Tk()        #创建主窗口对象
    app = RSAApp(root)    #构造实例
    root.mainloop()

结果示范

密钥生成

在这里插入图片描述

加密

在这里插入图片描述
在这里插入图片描述

解密

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/675797.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】查看进程在哪个CPU上运行

当前服务器是多核&#xff0c;在进行性能压测时&#xff0c;需要除了要观测全局的CPU使用率&#xff0c;对于单进程单线程往往需要在一个cpu上运行&#xff0c;那如何查看进程在哪个CPU上运行呢&#xff1f; 方法一&#xff1a;taskset taskset命令主要是用来检索或设置一个处…

RTPS协议之Structure

目录 概览RTPS中的各实体和类RTPS实体和类的属性类型&#xff1a;RTPS Entities属性 HistoryCacheCacheChangeRTPS EntityRTPS ParticipantRTPS EndPointRTPS WriterRTPS Reader和DDS Entities的关联DDS DataWriterDDS DataReader 每个RTPS实体和DDS实体是一对一对应的。Histor…

Bidirectional Copy-Paste for Semi-Supervised Medical Image Segmentation

文章目录 1. 问题背景2. 本文方法2.1. 模型图2.2. 损失函数 2. 模型的训练流程图3. 实验 1. 问题背景 &#xff08;1&#xff09;在半监督医学图像分割任务中&#xff0c;标签数据和无标签数据之间存在经验失配问题。 &#xff08;2&#xff09;如果采用分隔的方式或者采用不一…

lua vm 二: 查看字节码、看懂字节码

本文讲一讲如何查看 lua 的字节码&#xff08;bytecode&#xff09;&#xff0c;以及如何看懂字节码。 以下分析基于 lua-5.4.6&#xff0c;下载地址&#xff1a;https://lua.org/ftp/ 。 1. 查看字节码 1.1 方法一&#xff1a;使用 luac luac 是 lua 自带的编译程序&#x…

Django的PATH路径转换器

本书1-7章样章及配套资源下载链接: https://pan.baidu.com/s/1OGmhHxEMf2ZdozkUnDkAkA?pwdnanc 源码、PPT课件、教学视频等&#xff0c;可以从前言给出的下载信息下载&#xff0c;大家可以评估一下。 在Django框架中&#xff0c;默认内置了一组PATH路径转换器&#xff0c;具…

Chromebook也可以安装Visual Studio Code

文章目录 ​一、Chromebook也可以安装Visual Studio Code二、chromebook硬件条件三、在chromebook上启用Linux四、安装VS Code推荐阅读 ​一、Chromebook也可以安装Visual Studio Code 在过去几年里&#xff0c;运行谷歌Chrome操作系统的Chromebook一直在作为传统笔记本电脑的…

css 图片上添加模糊背景的文字内容

html部分 <div class"onlogo"> <img src"../assets/img/banner.png" /><div class"imgText"><div class"title">一体化电子印章应用服务</div><div class"content">为企业提供安全可靠…

OverlayFS在嵌入式系统中的应用

文章目录 抛出问题基本概念使用场景OverlayFS的详细介绍框架目录合并修改文件删除文件添加文件小结 OverlayFS在嵌入式系统中的应用内核配置OverlayFS简单应用OverlayFS应用新思路 总结 环境介绍 硬件&#xff1a;T113平台 软件&#xff1a;Tina5.0 SDK&#xff08;使用的build…

RocketMQ中client_log非常大

rocketmq默认不使用logback日志&#xff0c;所以得额外配置&#xff0c;使mq使用logback配置 使用logback中的日志配置 配置MQ 使用logback的配置,具体原理见ClientLogger.java的static代码块 在应用启动函数中添加如下代码 System.*setProperty*(ClientLogger.*CLIENT_LOG_USE…

Coolmuster Android助手评测:简化Android到电脑的联系人传输

产品概述 Coolmuster Android助手是一款旨在简化Android设备与计算机之间数据管理和传输过程的全面工具。它以用户友好的界面和全面的功能&#xff0c;成为寻求高效数据管理解决方案的Android用户的热门选择。 主要特点和功能Coolmuster Android助手拥有一系列使其成为管理Andr…

TMS FNC WX Pack TMS软件分发的一组应用程序

TMS FNC WX Pack TMS软件分发的一组应用程序 TMS FNC WX Pack是由TMS软件分发的一组应用程序。这些活动是100%的跨平台和跨Frimorc&#xff0c;并在不同的应用程序中得到支持&#xff0c;如Web应用程序、Windows、Linux等。阿拉伯语视觉组件库。安装这些计算机的过程非常简单高…

postman教程-10-使用cookie

领取资料&#xff0c;咨询答疑&#xff0c;请➕wei: June__Go 上一小节我们学习了Postman Authorization授权的几种方法&#xff0c;本小节我们讲解一下Postman 使用cookie的方法。 Postman 的 cookie 管理器使您能够查看和编辑与不同域关联的 cookie。您可以为域手动创建 c…

Windows10 设置默认编码为utf-8

Windows10 设置默认编码为utf-8 序言步骤 序言 有一些程序&#xff0c;默认读取出来gbk的会报错&#xff0c;有很多都是&#xff0c;干脆就直接设置电脑为默认utf-8的&#xff0c;这样就不用担心读取成gbk的怎么样了&#xff0c;具体是否需要要看自己的程序 步骤 完成了

高端、大气、很牛B的免费wordpress模板主题

这是一款专为WordPress打造的极简主义风格主题&#xff0c;以白色和黑色为主色调&#xff0c;搭配红色点缀&#xff0c;营造出一种简洁、专业且具有视觉冲击力的效果。 该主题的设计理念是“简单即美”&#xff0c;旨在帮助用户快速搭建一个美观、易用的网站。它提供了丰富的自…

【Java】接口详解

接口是抽象类的更进一步. 抽象类中还可以包含非抽象方法, 和字段. 而接口中包含的方法都是抽象方法, 字段只能包含静态常量。 一个简单的接口代码示例 interface IShape { void draw(); } class Cycle implements IShape { Override public void draw() { System.out.println…

如何制作一本温馨的电子相册呢?

随着科技的不断发展&#xff0c;电子相册已经成为了一种流行的方式来记录和分享我们的生活。一张张照片&#xff0c;一段段视频&#xff0c;都能让我们回忆起那些温馨的时光。那么&#xff0c;如何制作一本温馨的电子相册呢&#xff1f; 首先&#xff0c;选择一款合适的电子相册…

绕过WAF(Web应用程序防火墙)--介绍、主要功能、部署模式、分类及注入绕过方式等

网站WAF是一款集网站内容安全防护、网站资源保护及网站流量保护功能为一体的服务器工具。功能涵盖了网马/木马扫描、防SQL注入、防盗链、防CC攻击、网站流量实时监控、网站CPU监控、下载线程保护、IP黑白名单管理、网页防篡改功能等模块。能够为用户提供实时的网站安全防护&…

Docker无法stop或者rm指定容器

Docker无法stop或者rm指定容器 今日准备重启一下docker 容器部署的 Nginx 时&#xff0c;使用的命令是 docker exec -it ir-nginx nginx -s reload 结果发现无法重启报错 然后想着关闭再启动&#xff0c;结果发现 docker restart 、docker stop 、docker kill 、docker exec 都…

STM32-15-DMA

STM32-01-认识单片机 STM32-02-基础知识 STM32-03-HAL库 STM32-04-时钟树 STM32-05-SYSTEM文件夹 STM32-06-GPIO STM32-07-外部中断 STM32-08-串口 STM32-09-IWDG和WWDG STM32-10-定时器 STM32-11-电容触摸按键 STM32-12-OLED模块 STM32-13-MPU STM32-14-FSMC_LCD 文章目录 STM…

基础—SQL—DQL(数据查询语言)条件查询

一、DQL—语法 SELECT 字段列表 FROM 表名 WHERE 条件列表; 注意&#xff1a;条件列表可以是一个&#xff0c;也可以是多个。 二、条件列表的一些构建形式 注意&#xff1a; 1、BETWEEN ... AND ... &#xff08;between 后面跟最小值&#xff0c;and 后面跟最大值&#xff0…