Java编程实现非对称加密的方法详解

yizhihongxing

Java编程实现非对称加密的方法详解

非对称加密算法需要公钥和私钥。公钥可以对任意一个字符串进行加密,但只能用对应的私钥进行解密;私钥可以对任何一个字符串进行解密,但是只有对应的公钥能够进行加密。

生成密钥对

Java提供了多种非对称加密算法,比如RSA算法。使用Java生成RSA密钥对的过程如下:

import java.security.KeyPair;
import java.security.KeyPairGenerator;

KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
keyPairGenerator.initialize(2048); // 初始化密钥长度为2048位
KeyPair keyPair = keyPairGenerator.genKeyPair();

byte[] publicKeyBytes = keyPair.getPublic().getEncoded();
byte[] privateKeyBytes = keyPair.getPrivate().getEncoded();

实例化 KeyPairGenerator 对象可以通过其提供者或者算法名称实现,这里我们使用 RSA 算法,密钥长度为2048位。调用 genKeyPair 方法就可以获得 KeyPair 对象。通过 getPublic 和 getPrivate 方法可以获取 PublicKey 和 PrivateKey,再使用 getEncoded 方法转换成二进制格式的字节串,方便存储或传输。

加密

使用公钥加密一个字符串:

import java.security.PublicKey;
import javax.crypto.Cipher;

String plainText = "Hello, world.";
byte[] publicKeyBytes = ...; // 获取公钥的二进制格式字节串
PublicKey publicKey = KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(publicKeyBytes));

Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
byte[] encryptedBytes = cipher.doFinal(plainText.getBytes("UTF-8"));

实例化 PublicKey 对象需要通过 KeyFactory 和 X509EncodedKeySpec 进行转换,在 Cipher 中使用公钥和 ENCRYPT_MODE 初始化后,调用 doFinal 方法将明文转换为密文(字节数组)。

解密

使用私钥解密上一步所得到的密文:

import java.security.PrivateKey;

byte[] privateKeyBytes = ...; // 获取私钥的二进制格式字节串
PrivateKey privateKey = KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(privateKeyBytes));

cipher.init(Cipher.DECRYPT_MODE, privateKey);
byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
String plainText = new String(decryptedBytes, "UTF-8");

同样地,实例化 PrivateKey 对象需要通过 KeyFactory 和 PKCS8EncodedKeySpec 进行转换,在 Cipher 中使用私钥和 DECRYPT_MODE 初始化后,调用 doFinal 方法将密文转换为明文。

示例说明

示例 1:加密字符串并进行解密

import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import javax.crypto.Cipher;

public class AsymmetricEncryptionExample {
    public static void main(String[] args) throws Exception {
        String plainText = "Hello, world.";

        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
        keyPairGenerator.initialize(2048); // 初始化密钥长度为2048位
        KeyPair keyPair = keyPairGenerator.genKeyPair();

        byte[] publicKeyBytes = keyPair.getPublic().getEncoded();
        byte[] privateKeyBytes = keyPair.getPrivate().getEncoded();

        PublicKey publicKey = KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(publicKeyBytes));
        PrivateKey privateKey = KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(privateKeyBytes));

        Cipher cipher = Cipher.getInstance("RSA");

        cipher.init(Cipher.ENCRYPT_MODE, publicKey);
        byte[] encryptedBytes = cipher.doFinal(plainText.getBytes("UTF-8"));
        System.out.println("Encrypted: " + new String(encryptedBytes, "UTF-8"));

        cipher.init(Cipher.DECRYPT_MODE, privateKey);
        byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
        String decryptedText = new String(decryptedBytes, "UTF-8");
        System.out.println("Decrypted: " + decryptedText);
    }
}

输出:

Encrypted: ?0Mf???F???n@G?P?4?p??jd?g?z$?F?5?Xv?

Decrypted: Hello, world.

示例 2:使用公钥加密并传输密文,使用私钥解密

// 发送端
public class AsymmetricEncryptionExample {
    public static void main(String[] args) throws Exception {
        String plainText = "Hello, world.";

        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
        keyPairGenerator.initialize(2048); // 初始化密钥长度为2048位
        KeyPair keyPair = keyPairGenerator.genKeyPair();

        byte[] publicKeyBytes = keyPair.getPublic().getEncoded();

        PublicKey publicKey = KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(publicKeyBytes));

        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.ENCRYPT_MODE, publicKey);
        byte[] encryptedBytes = cipher.doFinal(plainText.getBytes("UTF-8"));

        System.out.println("Encrypted: " + new String(encryptedBytes, "UTF-8"));

        // 假设将 encryptedBytes 转换成Base64编码的字符串,传给接收端
    }
}

// 接收端
public class AsymmetricEncryptionExample {
    public static void main(String[] args) throws Exception {
        byte[] encryptedBytes = ...; // 假设获取到 Base64 编码的密文,解码成字节数组
        byte[] privateKeyBytes = ...; // 获取私钥的二进制格式字节串

        PrivateKey privateKey = KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(privateKeyBytes));

        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.DECRYPT_MODE, privateKey);
        byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
        String decryptedText = new String(decryptedBytes, "UTF-8");
        System.out.println("Decrypted: " + decryptedText);
    }
}

输出:

Decrypted: Hello, world.

在示例2中,发送端和接收端都需要获取密钥对中的公钥或私钥。为了简便起见,这里省略了从文件、数据库等外部存储中获取密钥的部分。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java编程实现非对称加密的方法详解 - Python技术站

(0)
上一篇 2023年5月26日
下一篇 2023年5月26日

相关文章

  • Java零基础精通方法篇

    Java零基础精通方法篇攻略 Java作为一门在现代编程界十分流行的语言,其学习曲线也是比较陡峭的。学习方法很重要,下面是一些针对Java零基础学习的方法。 1. 确定学习路线 Java语言许多知识点非常广泛,在学习Java之前,了解和确定自己所要学习的路线非常重要。建议先学习Java基本语法,然后跟随Java的应用功能,例如网络编程、GUI编程、并发等。同…

    Java 2023年5月23日
    00
  • 快速解决Tomcat启动慢的问题,超简单

    以下是“快速解决Tomcat启动慢的问题,超简单”的攻略: 问题描述 Tomcat 是一个广泛使用的 Java Web 服务器,但是在启动的时候有时会比较慢,特别是第一次启动。这个问题可能会给用户带来不好的体验,所以我们需要找到一种简单有效的方法来解决这个问题。 诊断原因 在解决 Tomcat 启动慢的问题之前,我们需要确认问题的具体原因。通常,慢启动可能有…

    Java 2023年6月2日
    00
  • layui点击弹框页面 表单请求的方法

    下面我将详细讲解“layui点击弹框页面 表单请求的方法”的完整攻略。 1. 使用LayUI的弹出层实现表单弹框 使用LayUI,我们可以通过layer模块来实现弹出层效果,并且可以嵌入表单(form)来进行数据提交。 下面是一个简单的示例代码,实现了一个点击按钮后,弹出一个表单的效果。 <!DOCTYPE html> <html> …

    Java 2023年6月15日
    00
  • Servlet+JDBC实现登陆功能的小例子(带验证码)

    下面是“Servlet+JDBC实现登陆功能的小例子(带验证码)”的完整攻略,包含以下内容: 需求分析 我们需要实现一个包含验证码的登陆功能,用户需要输入用户名、密码和验证码,当用户点击提交按钮时,系统会校验用户的输入,如果输入正确,则跳转到登录成功页面,否则提示错误信息。 技术选择 我们使用Servlet技术实现用户输入数据的接收和校验,使用JDBC技术实…

    Java 2023年6月15日
    00
  • SpringBoot详细讲解视图整合引擎thymeleaf

    让我来详细讲解一下“SpringBoot详细讲解视图整合引擎thymeleaf”的完整攻略。 1. 什么是Thymeleaf Thymeleaf是一种现代化的服务器端模板引擎,可支持HTML、CSS、XML、JavaScript等文档类型。它的语法十分简单且灵活,可以通过简单而自然的模板表达式快速地构建出动态内容渲染的视图。 2. 如何整合Thymeleaf…

    Java 2023年5月19日
    00
  • 纯js代码生成可搜索选择下拉列表的实例

    生成可搜索选择下拉列表的实例,首先需要编写一个基本的HTML结构: <input type="text" id="searchBox" placeholder="搜索…"> <select id="selectBox"></select> …

    Java 2023年6月15日
    00
  • 梦三国中单solo心得讲解

    梦三国中单solo心得讲解 梦三国是一款非常热门的游戏,其中中单solo是非常重要的一个位置。下面我将详细讲解梦三国中单solo的攻略。 选手的选择 在选择选手的时候,我们需要考虑以下几点: 选手的属性: 每个选手都有自己的属性,包括攻击力、防御力、技能等级等等。 选手的定位: 不同的选手定位不同,有刺客、法师、坦克等。我们可以根据对手选择相应的选手。 选手…

    Java 2023年6月15日
    00
  • 一文掌握Java开发工具Maven(简单上手)

    一文掌握Java开发工具Maven(简单上手) 什么是Maven? Maven是一个用于构建Java项目的工具,它帮助我们自动化构建、测试、打包和发布Java应用程序。通过传递性依赖关系,Maven可以帮助我们管理项目中的依赖项,使得我们可以更好地管理我们的应用程序。 Maven的安装和配置 安装Maven 下载Maven二进制包 解压缩到你要安装的目录下 …

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部