密码学课程Java简单实现RSA加解密算法

这篇博客介绍了如何使用Java实现RSA加密算法,重点在于理解算法的核心思想,包括质数判断、公钥私钥生成及加解密过程。虽然代码简化处理,未考虑数据溢出和效率问题,但提供了完整的类结构,包括RSA_Algrithm、Multiplicative_Inverse、Input、Check和Test类。读者可以在此基础上进行优化和测试。
摘要由CSDN通过智能技术生成

Java简单实现RSA加解密算法

由于时间匆忙,笔者抽了点时间简单写了一个RSA加密算法的实现,重在体现RSA算法的经典核心思想,因此没有考虑到其他数据溢出、运行效率等Bug或问题,后续代码的优化和整理劳请各位读者提出意见,谢谢

算法思想:

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

算法实现

使用工具:Java
环境平台:Eclipse , jdk11.0.2 , Win10
在这里插入图片描述

RSA_Algrithm类:

包含了算法的核心参数p,q,n,fn,e,d
在这里插入图片描述
以及
判断用户输入的两个数是否为质数的判断函数inputTwoPrimes
随机生成0~fn且与fn互质的公钥的生成函数generatePublicKey_e
通过公钥求解对应的私钥的函数generatePrivateKey_d
加密函数encryption 和 解密函数decryption
代码如下:

package rsa_algrithm;

import java.util.Scanner;

public class RSA_Algrithm {
   

	protected static int p ;  //输入的第一个素数
	protected static int q ;  //输入的第二个素数

	protected static int n ;  //加密和解密时的模值
	protected static int fn ; //通过公钥求解私钥时的模值
	
	protected static int e;   //公钥
	protected static int d;   //私钥

	//输入两个不相同的质数
	public static void inputTwoPrimes() {
   
		
		while(p == q) {
      //p和q的初始没有赋,所以初值都为0
		
		//输入第一个质数
		do {
   
       	    System.out.print("Please input the first prime: ");
       	    Scanner scanner1 =  new Scanner (System.in );  
       	    p = scanner1.nextInt();
		    Input.inputPrime(p);
		   }while(Input.flag == false);
		
		//输入第二个质数
		do {
   
	       	System.out.print("Please input the second prime: ");
	       	Scanner scanner2 =  new Scanner (System.in )
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值