文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

利用Java怎么编写一个DES加密解密工具类

2023-05-31 01:36

关注

今天就跟大家聊聊有关利用Java怎么编写一个DES加密解密工具类,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

DesUtil.java

package lsy;import java.security.Key;import java.security.SecureRandom;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import javax.crypto.SecretKey;import sun.misc.BASE64Decoder;import sun.misc.BASE64Encoder;public class DesUtil {  public static void main(String[] args) {  //以下是加密方法algorithm="AES"的测试  System.out.println(DesUtil.getInstance("lushuaiyin").getEnCodeString("hello"));  //输出 LDewGAZkmWHeYFjBz56ylw==  //将上面的密文解密:  System.out.println(DesUtil.getInstance("lushuaiyin").getDecodeString("LDewGAZkmWHeYFjBz56ylw=="));  //输出 hello  //改变密钥测试  System.out.println(DesUtil.getInstance("suolong").getEnCodeString("hello"));  //输出 /RLowOJ+Fr3KdMcdJeNatg==  System.out.println(DesUtil.getInstance("suolong").getDecodeString("/RLowOJ+Fr3KdMcdJeNatg=="));  //输出 hello  //如果使用不正确的密钥解密,将会:  System.out.println(DesUtil.getInstance("suolong").getDecodeString("LDewGAZkmWHeYFjBz56ylw==")); } private SecretKey key=null;//密钥 //定义 加密算法,可用 DES,DESede,Blowfish,AES //不同的加密方式结果会不同 private static String algorithm="AES"; private static DesUtil desUtil=null; public DesUtil(){} public static DesUtil getInstance(String strKey){  desUtil=new DesUtil();  desUtil.createKey(strKey);  return desUtil; }  public void createKey(String strKey){  try{   KeyGenerator kg=KeyGenerator.getInstance(DesUtil.algorithm);   byte[] bt=strKey.getBytes("UTF-8");   SecureRandom sr=new SecureRandom(bt);   kg.init(sr);   this.setKey(kg.generateKey());  }catch(Exception e){  } }  public String getEnCodeString(String dataStr){  byte[] miwen=null;//密文  byte[] mingwen=null;//明文  Cipher cipher;  String result="";//密文字符串  try{   mingwen=dataStr.getBytes("UTF-8");   cipher=Cipher.getInstance(DesUtil.algorithm);   cipher.init(Cipher.ENCRYPT_MODE, this.getKey());   miwen=cipher.doFinal(mingwen);   BASE64Encoder base64en = new BASE64Encoder();   result=base64en.encodeBuffer(miwen);//或者可以用下面的方法得到密文,结果是不一样的,都可以正常解密//   result=byte2hex(miwen);//密文结果类似2C:37:B0:18:06:64:99:61:DE:60:58:C1:CF:9E:B2:97  }catch(Exception e){   e.printStackTrace();  }  return result; }  public String getDecodeString(String codeStr){  BASE64Decoder base64De = new BASE64Decoder();  byte[] miwen=null;  byte[] mingwen=null;  String resultData="";//返回的明文  Cipher cipher;  try{   miwen=base64De.decodeBuffer(codeStr);   cipher=Cipher.getInstance(DesUtil.algorithm);   cipher.init(Cipher.DECRYPT_MODE, this.getKey());   mingwen=cipher.doFinal(miwen);   resultData = new String(mingwen,"UTF-8");  }catch(Exception e){   return "密钥不正确或其他原因导致异常,无法解密!";  }  return resultData; }  //二行制转字符串 public String byte2hex(byte[] b) {  String hs = "";  String stmp = "";  for (int n = 0; n < b.length; n++) {   stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));   if (stmp.length() == 1)    hs = hs + "0" + stmp;   else    hs = hs + stmp;   if (n < b.length - 1)    hs = hs + ":";  }  return hs.toUpperCase(); } public SecretKey getKey() {  return key; } public void setKey(SecretKey key) {  this.key = key; } public static String getAlgorithm() {  return algorithm; } public static void setAlgorithm(String algorithm) {  algorithm = algorithm; }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯