gpt4 book ai didi

Java实现的DES加密解密工具类实例

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Java实现的DES加密解密工具类实例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

本文实例讲述了Java实现的DES加密解密工具类。分享给大家供大家参考,具体如下:

一个工具类,很常用,不做深入研究了,那来可直接用 。

DesUtil.java 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
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 {
  /**
   * @param args
   */
  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;
  }
  /**
   * algorithm 算法
   * @param strKey
   */
  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){
   }
  }
  /**
   * 加密方法,返回密文
   * cipher 密码
   * @param dataStr
   */
  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;
  }
  /**
   * 解密方法,返回明文
   * @param codeStr
   * @return
   */
  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;
  }
}

运行结果:

?
1
2
3
4
5
LDewGAZkmWHeYFjBz56ylw==
hello
/RLowOJ+Fr3KdMcdJeNatg==
hello
密钥不正确或其他原因导致异常,无法解密!

希望本文所述对大家java程序设计有所帮助.

原文链接:http://blog.csdn.net/lushuaiyin/article/details/7820600 。

最后此篇关于Java实现的DES加密解密工具类实例的文章就讲到这里了,如果你想了解更多关于Java实现的DES加密解密工具类实例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com