全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Java中常用加密/解密方法详解

安全问题已经成为一个越来越重要的问题,在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各种加密与解密方式总结大全  # 自动生成  # 所需  # 是一种  # 已被  # 我们可以  # 可以通过  # 可以使用  # 美国  # 成为一个  # 主要内容  # 自带  # 第三方  # 最流行  # 开源  # 在国际上  # 就可以  # 而是一种  # 不是一种  # 向明 


相关文章: 制作公司内部网站有哪些,内网如何建网站?  ppt制作免费网站有哪些,ppt模板免费下载网站?  建站主机核心功能解析:服务器选择与网站搭建流程指南  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  如何在IIS中新建站点并解决端口绑定冲突?  实例解析Array和String方法  建站之星24小时客服电话如何获取?  淘宝制作网站有哪些,淘宝网官网主页?  网站制作员失业,怎样查看自己网站的注册者?  建站之星代理平台如何选择最佳方案?  红河网站制作公司,红河事业单位身份证如何上传?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  如何在腾讯云免费申请建站?  平台云上自助建站如何快速打造专业网站?  建站之星免费模板:自助建站系统与智能响应式一键生成  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何快速搭建二级域名独立网站?  高防服务器租用如何选择配置与防御等级?  如何通过VPS建站无需域名直接访问?  安云自助建站系统如何快速提升SEO排名?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  北京企业网站设计制作公司,北京铁路集团官方网站?  建站之星后台密码遗忘如何找回?  如何选择最佳自助建站系统?快速指南解析优劣  建站主机CVM配置优化、SEO策略与性能提升指南  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  如何在云主机上快速搭建网站?  内部网站制作流程,如何建立公司内部网站?  网站企业制作流程,用什么语言做企业网站比较好?  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  如何制作一个表白网站视频,关于勇敢表白的小标题?  如何获取PHP WAP自助建站系统源码?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  历史网站制作软件,华为如何找回被删除的网站?  *服务器网站为何频现安全漏洞?  如何高效配置香港服务器实现快速建站?  如何在阿里云ECS服务器部署织梦CMS网站?  如何在云主机上快速搭建多站点网站?  图册素材网站设计制作软件,图册的导出方式有几种?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  建站之星安装路径如何正确选择及配置?  宝塔新建站点报错如何解决?  ,购物网站怎么盈利呢?  如何选择高效稳定的ISP建站解决方案?  建站上传速度慢?如何优化加速网站加载效率?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  网站app免费制作软件,能免费看各大网站视频的手机app? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。