JAVA中AES对称加密和解密过程

时间:2021-11-04 15:57:27

AES对称加密和解密代码详细介绍,供大家参考,具体内容如下 

?
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
package demo.security;
 
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.Base64;
import java.util.Scanner;
 
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 sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
 
/*
 * AES对称加密和解密
 */
public class SymmetricEncoder {
 /*
  * 加密
  * 1.构造密钥生成器
  * 2.根据ecnodeRules规则初始化密钥生成器
  * 3.产生密钥
  * 4.创建和初始化密码器
  * 5.内容加密
  * 6.返回字符串
  */
  public static String AESEncode(String encodeRules,String content){
    try {
      //1.构造密钥生成器,指定为AES算法,不区分大小写
      KeyGenerator keygen=KeyGenerator.getInstance("AES");
      //2.根据ecnodeRules规则初始化密钥生成器
      //生成一个128位的随机源,根据传入的字节数组
      keygen.init(128, new SecureRandom(encodeRules.getBytes()));
       //3.产生原始对称密钥
      SecretKey original_key=keygen.generateKey();
       //4.获得原始对称密钥的字节数组
      byte [] raw=original_key.getEncoded();
      //5.根据字节数组生成AES密钥
      SecretKey key=new SecretKeySpec(raw, "AES");
       //6.根据指定算法AES自成密码器
      Cipher cipher=Cipher.getInstance("AES");
       //7.初始化密码器,第一个参数为加密(Encrypt_mode)或者解密解密(Decrypt_mode)操作,第二个参数为使用的KEY
      cipher.init(Cipher.ENCRYPT_MODE, key);
      //8.获取加密内容的字节数组(这里要设置为utf-8)不然内容中如果有中文和英文混合中文就会解密为乱码
      byte [] byte_encode=content.getBytes("utf-8");
      //9.根据密码器的初始化方式--加密:将数据加密
      byte [] byte_AES=cipher.doFinal(byte_encode);
     //10.将加密后的数据转换为字符串
      //这里用Base64Encoder中会找不到包
      //解决办法:
      //在项目的Build path中先移除JRE System Library,再添加库JRE System Library,重新编译后就一切正常了。
      String AES_encode=new String(new BASE64Encoder().encode(byte_AES));
     //11.将字符串返回
      return AES_encode;
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    } catch (NoSuchPaddingException e) {
      e.printStackTrace();
    } catch (InvalidKeyException e) {
      e.printStackTrace();
    } catch (IllegalBlockSizeException e) {
      e.printStackTrace();
    } catch (BadPaddingException e) {
      e.printStackTrace();
    } catch (UnsupportedEncodingException e) {
      e.printStackTrace();
    }
    
    //如果有错就返加nulll
    return null;    
  }
  /*
   * 解密
   * 解密过程:
   * 1.同加密1-4步
   * 2.将加密后的字符串反纺成byte[]数组
   * 3.将加密内容解密
   */
  public static String AESDncode(String encodeRules,String content){
    try {
      //1.构造密钥生成器,指定为AES算法,不区分大小写
      KeyGenerator keygen=KeyGenerator.getInstance("AES");
      //2.根据ecnodeRules规则初始化密钥生成器
      //生成一个128位的随机源,根据传入的字节数组
      keygen.init(128, new SecureRandom(encodeRules.getBytes()));
       //3.产生原始对称密钥
      SecretKey original_key=keygen.generateKey();
       //4.获得原始对称密钥的字节数组
      byte [] raw=original_key.getEncoded();
      //5.根据字节数组生成AES密钥
      SecretKey key=new SecretKeySpec(raw, "AES");
       //6.根据指定算法AES自成密码器
      Cipher cipher=Cipher.getInstance("AES");
       //7.初始化密码器,第一个参数为加密(Encrypt_mode)或者解密(Decrypt_mode)操作,第二个参数为使用的KEY
      cipher.init(Cipher.DECRYPT_MODE, key);
      //8.将加密并编码后的内容解码成字节数组
      byte [] byte_content= new BASE64Decoder().decodeBuffer(content);
      /*
       * 解密
       */
      byte [] byte_decode=cipher.doFinal(byte_content);
      String AES_decode=new String(byte_decode,"utf-8");
      return AES_decode;
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    } catch (NoSuchPaddingException e) {
      e.printStackTrace();
    } catch (InvalidKeyException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    } catch (IllegalBlockSizeException e) {
      e.printStackTrace();
    } catch (BadPaddingException e) {
      e.printStackTrace();
    }
    
    //如果有错就返加nulll
    return null;    
  }
  
  public static void main(String[] args) {
    SymmetricEncoder se=new SymmetricEncoder();
    Scanner scanner=new Scanner(System.in);
    /*
     * 加密
     */
    System.out.println("使用AES对称加密,请输入加密的规则");
    String encodeRules=scanner.next();
    System.out.println("请输入要加密的内容:");
    String content = scanner.next();
    System.out.println("根据输入的规则"+encodeRules+"加密后的密文是:"+se.AESEncode(encodeRules, content));
    
    /*
     * 解密
     */
    System.out.println("使用AES对称解密,请输入加密的规则:(须与加密相同)");
     encodeRules=scanner.next();
    System.out.println("请输入要解密的内容(密文):");
     content = scanner.next();
    System.out.println("根据输入的规则"+encodeRules+"解密后的明文是:"+se.AESDncode(encodeRules, content));
  }
 
}

测试结果:

使用AES对称加密,请输入加密的规则
使用AES对称加密
请输入要加密的内容:
使用AES对称加密
根据输入的规则使用AES对称加密加密后的密文是:Z0NwrNPHghgXHN0CqjLS58YCjhMcBfeR33RWs7Lw+AY=
使用AES对称解密,请输入加密的规则:(须与加密相同)
使用AES对称加密
请输入要解密的内容(密文):
Z0NwrNPHghgXHN0CqjLS58YCjhMcBfeR33RWs7Lw+AY=
根据输入的规则使用AES对称加密解密后的明文是:使用AES对称加密

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。