Java中常用加密/解密方法详解
发布时间 - 2026-01-10 23:07:52 点击率:次安全问题已经成为一个越来越重要的问题,在Java中如何对重要数据进行加密解密是本文的主要内容。

一、常用的加密/解密算法
1.Base64
严格来说Base64并不是一种加密/解密算法,而是一种编码方式。Base64不生成密钥,通过Base64编码后的密文就可以直接“翻译”为明文,但是可以通过向明文中添加混淆字符来达到加密的效果。
2.DES
DES是一种基于56位密钥的对称算法,1976年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),随后在国际上广泛流传开来。现在DES已经不是一种安全的加密算法,已被公开破解,现在DES已经被高级加密标准(AES)所代替。
3.3DES
3DES是DES的一种派生算法,主要提升了DES的一些实用所需的安全性。
4.AES
AES是现在对称加密算法中最流行的算法之一。
二、实现所需的一些库
为了实现上述的算法,我们可以实用JDK自带的实现,也可以使用一些开源的第三方库,例如Bouncy Castle(https://www.bouncycastle.org/)和comnons codec(https://commons.apache.org/proper/commons-codec/)。
三、具体实现
1.Base64
package com.tancky.security;
import java.io.IOException;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class Base64Demo {
private static String src = "TestBase64";
public static void main(String[] args) {
Base64Demo.jdkBase64();
Base64Demo.commonsCodecBase64 ();
Base64Demo.bouncyCastleBase64 ();
}
//使用JDK的base64实现,
public static void jdkBase64 (){
BASE64Encoder encoder = new BASE64Encoder();
String encode = encoder.encode(Base64Demo.src.getBytes());
System.out.println("encode: " + encode);
BASE64Decoder decoder = new BASE64Decoder();
try {
String decode = new String ( decoder.decodeBuffer(encode));
System.out.println("decode: " + decode);
} catch (IOException e) {
e.printStackTrace();
}
}
//使用apache的commonsCodec实现
public static void commonsCodecBase64 (){
byte[] encodeBytes = org.apache.commons.codec.binary.Base64.encodeBase64(Base64Demo.src.getBytes());
String encode = new String (encodeBytes);
System.out.println("encode: " + encode);
byte[] decodeBytes = org.apache.commons.codec.binary.Base64.decodeBase64(encode);
String decode = new String(decodeBytes);
System.out.println("decode: " + decode);
}
//使用bouncyCastlede实现
public static void bouncyCastleBase64 () {
byte[] encodeBytes = org.bouncycastle.util.encoders.Base64.encode(Base64Demo.src.getBytes()) ;
String encode = new String (encodeBytes);
System.out.println("encode: " + encode);
byte[] decodeBytes = org.bouncycastle.util.encoders.Base64.decode(encode);
String decode = new String(decodeBytes);
System.out.println("decode: " + decode);
}
}
2.DES
package com.tancky.security;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.Security;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;
public class DESDemo {
private static String src = "TestDES";
public static void jdkDES () {
try {
//生成密钥Key
KeyGenerator keyGenerator = KeyGenerator.getInstance("DES");
keyGenerator.init(56);
SecretKey secretKey = keyGenerator.generateKey();
byte[] bytesKey = secretKey.getEncoded();
//KEY转换
DESKeySpec deSedeKeySpec = new DESKeySpec(bytesKey);
SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");
Key convertSecretKey = factory.generateSecret(deSedeKeySpec);
//加密
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, convertSecretKey);
byte[] encodeResult = cipher.doFinal(DESDemo.src.getBytes());
System.out.println("DESEncode :" + Hex.toHexString(encodeResult));
//解密
cipher.init(Cipher.DECRYPT_MODE,convertSecretKey);
byte[] DecodeResult = cipher.doFinal(encodeResult);
System.out.println("DESDncode :" + new String (DecodeResult));
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (InvalidKeySpecException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (BadPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
public static void bcDES (){
try {
//使用BouncyCastle 的DES加密
Security.addProvider(new BouncyCastleProvider());
//生成密钥Key
KeyGenerator keyGenerator = KeyGenerator.getInstance("DES","BC");
keyGenerator.init(56);
SecretKey secretKey = keyGenerator.generateKey();
byte[] bytesKey = secretKey.getEncoded();
//KEY转换
DESKeySpec deSedeKeySpec = new DESKeySpec(bytesKey);
SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");
Key convertSecretKey = factory.generateSecret(deSedeKeySpec);
//加密
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, convertSecretKey);
byte[] encodeResult = cipher.doFinal(DESDemo.src.getBytes());
System.out.println("DESEncode :" + Hex.toHexString(encodeResult));
//解密
cipher.init(Cipher.DECRYPT_MODE,convertSecretKey);
byte[] DecodeResult = cipher.doFinal(encodeResult);
System.out.println("DESDncode :" + new String (DecodeResult));
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (InvalidKeySpecException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (BadPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchProviderException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
public static void main(String[] args) {
DESDemo.jdkDES ();
DESDemo.bcDES();
}
}
3.3DES
package com.tancky.security;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.Security;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESedeKeySpec;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;
public class TripleDESDemo {
private static String src = "TestTripleDES";
public static void jdkTripleDES () {
try {
//生成密钥Key
KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede");
keyGenerator.init(168);
SecretKey secretKey = keyGenerator.generateKey();
byte[] bytesKey = secretKey.getEncoded();
//KEY转换
DESedeKeySpec deSedeKeySpec = new DESedeKeySpec(bytesKey);
SecretKeyFactory factory = SecretKeyFactory.getInstance("DESede");
Key convertSecretKey = factory.generateSecret(deSedeKeySpec);
//加密
Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, convertSecretKey);
byte[] encodeResult = cipher.doFinal(TripleDESDemo.src.getBytes());
System.out.println("TripleDESEncode :" + Hex.toHexString(encodeResult));
//解密
cipher.init(Cipher.DECRYPT_MODE,convertSecretKey);
byte[] DecodeResult = cipher.doFinal(encodeResult);
System.out.println("TripleDESDncode :" + new String (DecodeResult));
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (InvalidKeySpecException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (BadPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
public static void bcTripleDES () {
try {
Security.addProvider(new BouncyCastleProvider());
//生成密钥Key
KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede","BC");
keyGenerator.getProvider();
keyGenerator.init(168);
SecretKey secretKey = keyGenerator.generateKey();
byte[] bytesKey = secretKey.getEncoded();
//KEY转换
DESedeKeySpec deSedeKeySpec = new DESedeKeySpec(bytesKey);
SecretKeyFactory factory = SecretKeyFactory.getInstance("DESede");
Key convertSecretKey = factory.generateSecret(deSedeKeySpec);
//加密
Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, convertSecretKey);
byte[] encodeResult = cipher.doFinal(TripleDESDemo.src.getBytes());
System.out.println("TripleDESEncode :" + Hex.toHexString(encodeResult));
//解密
cipher.init(Cipher.DECRYPT_MODE,convertSecretKey);
byte[] DecodeResult = cipher.doFinal(encodeResult);
System.out.println("TripleDESDncode :" + new String (DecodeResult));
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (InvalidKeySpecException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (BadPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchProviderException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
public static void main(String[] args) {
jdkTripleDES ();
bcTripleDES ();
}
}
4.AES
package com.tancky.security;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.SecureRandom;
import java.security.Security;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;
public class AESDemo {
private static String src = "TestAES";
public static void jdkAES (){
try {
//生成Key
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
keyGenerator.init(128);
//keyGenerator.init(128, new SecureRandom("seedseedseed".getBytes()));
//使用上面这种初始化方法可以特定种子来生成密钥,这样加密后的密文是唯一固定的。
SecretKey secretKey = keyGenerator.generateKey();
byte[] keyBytes = secretKey.getEncoded();
//Key转换
Key key = new SecretKeySpec(keyBytes, "AES");
//加密
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, key);
byte[] encodeResult = cipher.doFinal(AESDemo.src.getBytes());
System.out.println("AESencode : " + Hex.toHexString(encodeResult) );
//解密
cipher.init(Cipher.DECRYPT_MODE, key);
byte[] decodeResult = cipher.doFinal(encodeResult);
System.out.println("AESdecode : " + new String (decodeResult));
} catch (NoSuchAlgorithmException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (BadPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
public static void bcAES (){
try {
//使用BouncyCastle 的DES加密
Security.addProvider(new BouncyCastleProvider());
//生成Key
KeyGenerator keyGenerator = KeyGenerator.getInstance("AES","BC");
keyGenerator.getProvider();
keyGenerator.init(128);
SecretKey secretKey = keyGenerator.generateKey();
byte[] keyBytes = secretKey.getEncoded();
//Key转换
Key key = new SecretKeySpec(keyBytes, "AES");
//加密
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, key);
byte[] encodeResult = cipher.doFinal(AESDemo.src.getBytes());
System.out.println("AESencode : " + Hex.toHexString(encodeResult) );
//解密
cipher.init(Cipher.DECRYPT_MODE, key);
byte[] decodeResult = cipher.doFinal(encodeResult);
System.out.println("AESdecode : " + new String (decodeResult));
} catch (NoSuchAlgorithmException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (BadPaddingException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} catch (NoSuchProviderException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}
public static void main(String[] args) {
jdkAES();
bcAES();
}
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# java
# 加密解密
# java常用加密解密算法
# Java实现MD5加密及解密的代码实例分享
# Java实现文件的加密解密功能示例
# java使用des加密解密示例分享
# Java对字符串进行加密解密
# 实例讲解java的纯数字加密解密
# JAVA各种加密与解密方式总结大全
# 自动生成
# 所需
# 是一种
# 已被
# 我们可以
# 可以通过
# 可以使用
# 美国
# 成为一个
# 主要内容
# 自带
# 第三方
# 最流行
# 开源
# 在国际上
# 就可以
# 而是一种
# 不是一种
# 向明
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
Laravel PHP版本要求一览_Laravel各版本环境要求对照
PHP正则匹配日期和时间(时间戳转换)的实例代码
Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】
iOS正则表达式验证手机号、邮箱、身份证号等
韩国服务器如何优化跨境访问实现高效连接?
如何有效防御Web建站篡改攻击?
Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】
实现点击下箭头变上箭头来回切换的两种方法【推荐】
Laravel如何实现API资源集合?(Resource Collection教程)
三星、SK海力士获美批准:可向中国出口芯片制造设备
网站制作报价单模板图片,小松挖机官方网站报价?
Laravel定时任务怎么设置_Laravel Crontab调度器配置
如何快速使用云服务器搭建个人网站?
如何快速查询网址的建站时间与历史轨迹?
Python函数文档自动校验_规范解析【教程】
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
如何在宝塔面板创建新站点?
JavaScript模板引擎Template.js使用详解
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
php 三元运算符实例详细介绍
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
Laravel API资源类怎么用_Laravel API Resource数据转换
免费视频制作网站,更新又快又好的免费电影网站?
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】
JavaScript如何实现错误处理_try...catch如何捕获异常?
原生JS实现图片轮播切换效果
如何在服务器上配置二级域名建站?
如何获取免费开源的自助建站系统源码?
Laravel安装步骤详细教程_Laravel环境搭建指南
如何在VPS电脑上快速搭建网站?
Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知
如何用VPS主机快速搭建个人网站?
Laravel如何发送系统通知?(Notification渠道示例)
使用PHP下载CSS文件中的所有图片【几行代码即可实现】
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
油猴 教程,油猴搜脚本为什么会网页无法显示?
,南京靠谱的征婚网站?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
详解Android图表 MPAndroidChart折线图
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
如何在搬瓦工VPS快速搭建网站?
Laravel怎么使用Intervention Image库处理图片上传和缩放

