首页 > Java > java教程 > 正文

Java中的对称加密密码学

WBOY
发布: 2023-09-13 15:49:02
转载
1526人浏览过

java中的对称加密密码学

简介

对称加密,也称为密钥加密,是一种加密方法,其中相同的密钥用于加密和解密。这种加密方法快速高效,适用于加密大量数据。最常用的对称加密算法是高级加密标准(AES)。

Java提供了对称加密的强大支持,其中包括javax.crypto包中的类,如SecretKey、Cipher和KeyGenerator。

Java 中的对称加密

javax.crypto 包中的 Java Cipher 类提供了加密和解密的密码功能。它构成了 Java 加密扩展 (JCE) 框架的核心。

在Java中,Cipher类提供对称加密的功能,而KeyGenerator类用于生成对称加密的密钥。

立即学习Java免费学习笔记(深入)”;

Example

的中文翻译为:

示例

让我们来看一个使用Java实现的简单对称加密AES的例子−

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import java.nio.charset.StandardCharsets;
import java.util.Base64;

public class Main {
   public static void main(String[] args) throws Exception {

      // Generate key
      SecretKey secretKey = KeyGenerator.getInstance("AES").generateKey();
   
      // Original message
      String originalMessage = "Hello, world!";
   
      // Create Cipher instance and initialize it to ENCRYPT_MODE
      Cipher cipher = Cipher.getInstance("AES");
      cipher.init(Cipher.ENCRYPT_MODE, secretKey);
   
      // Encrypt the message
      byte[] encryptedMessage = cipher.doFinal(originalMessage.getBytes(StandardCharsets.UTF_8));
   
      // Convert the encrypted message to Base64 encoded string
      String encodedMessage = Base64.getEncoder().encodeToString(encryptedMessage);
   
      System.out.println("Original Message: " + originalMessage);
      System.out.println("Encrypted Message: " + encodedMessage);
   
      // Reinitialize the cipher to DECRYPT_MODE
      cipher.init(Cipher.DECRYPT_MODE, secretKey);
   
      // Decrypt the message
      byte[] decryptedMessage = cipher.doFinal(Base64.getDecoder().decode(encodedMessage));
   
      System.out.println("Decrypted Message: " + new String(decryptedMessage, StandardCharsets.UTF_8));
   }
}
登录后复制

输出

当你运行程序时,你会看到类似于以下的输出 -

Original Message: Hello, world!
Encrypted Message: iWohhm/c89uBVaJ3j4YFkA==
Decrypted Message: Hello, world!
登录后复制

Explanation

的中文翻译为:

解释

在上面的代码中,我们首先使用KeyGenerator类生成AES加密的秘密密钥。

然后我们为AES创建一个Cipher类的实例,并使用秘密密钥将其初始化为ENCRYPT_MODE。

NameGPT名称生成器
NameGPT名称生成器

免费AI公司名称生成器,AI在线生成企业名称,注册公司名称起名大全。

NameGPT名称生成器 0
查看详情 NameGPT名称生成器

接下来,我们定义一条原始消息“Hello, world!”,并使用 Cipher 的 doFinal 方法对其进行加密。我们还将加密的消息字节转换为 Base64 编码的字符串,以使其更易于处理。

然后我们将原始消息和加密消息打印到控制台。

为了演示解密,我们使用相同的密钥将密码重新初始化为 DECRYPT_MODE 并解密加密的消息。最后,我们将解密后的消息打印到控制台。

由于每次运行程序都会生成唯一的秘密密钥,所以加密消息每次都会有所不同。

这里需要注意的重要一点是,解密的消息与原始消息相同,这表明我们的加密和解密过程正常工作。

记住的要点

对称加密是维护机密性的强大工具,但重要的是要记住,您的数据的安全性取决于密钥的安全性。如果未经授权的人获取了您的秘密密钥,他们可以解密您的数据。因此,保持秘密密钥的安全至关重要。

结论

在Java中实现对称加密是一个简单的过程,这要归功于javax.crypto包。了解如何使用Cipher和KeyGenerator类来加密和解密数据可以显着提升Java应用程序的安全性。

以上就是Java中的对称加密密码学的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:tutorialspoint网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号