原理

对于任意长度的明文,AES首先对其进行分组,每组的长度为128位。分组之后将分别对每个128位的明文分组进行加密。

对于每个128位长度的明文分组的加密过程如下:

(1)将128位AES明文分组放入状态矩阵中。

(2)AddRoundKey变换:对状态矩阵进行AddRoundKey变换,与膨胀后的密钥进行异或操作(密钥膨胀将在实验原理七中详细讨论)。

(3)10轮循环:AES对状态矩阵进行了10轮类似的子加密过程。前9轮子加密过程中,每一轮子加密过程包括4种不同的变换,而最后一轮只有3种变换,前9轮的子加密步骤如下:

  • ● SubBytes变换:SubBytes变换是一个对状态矩阵非线性的变换;
  • ● ShiftRows变换:ShiftRows变换对状态矩阵的行进行循环移位;
  • ● MixColumns变换:MixColumns变换对状态矩阵的列进行变换;
  • ● AddRoundKey变换:AddRoundKey变换对状态矩阵和膨胀后的密钥进行异或操作。
最后一轮的子加密步骤如下:
  • ● SubBytes变换:SubBytes变换是一个对状态矩阵非线性的变换;
  • ● ShiftRows变换:ShiftRows变换对状态矩阵的行进行循环移位;
  • ● AddRoundKey变换:AddRoundKey变换对状态矩阵和膨胀后的密钥进行异或操作;

(4)经过10轮循环的状态矩阵中的内容就是加密后的密文。

步骤

主要用到的java类有:

  • 类 Cipher

    java.lang.Object

    javax.crypto.Cipher,主要提供加密解密功能

  • 类 KeyGenerator

    java.lang.Object

    javax.crypto.KeyGenerator,此类提供(对称)密钥生成器的功能。

  • 接口 SecretKey

    所有超级接口:

    Key, Serializable

    所有已知子接口:

    PBEKey

    所有已知实现类:

    KerberosKey, SecretKeySpec

加密步骤

  1. 构造密钥生成器,指定为AES算法,不区分大小写
  2. 根据ecnodeRules规则初始化密钥生成器

    生成一个128位的随机源,根据传入的字节数组
  3. 产生原始对称密钥
  4. 获得原始对称密钥的字节数组
  5. 根据字节数组生成AES密钥
  6. 根据指定算法AES自成密码器
  7. 初始化密码器,第一个参数为加密(Encrypt_mode)或者解密解密(Decrypt_mode)操作,第二个参数为使用的KEY
  8. 获取加密内容的字节数组(这里要设置为utf-8)不然内容中如果有中文和英文混合中文就会解密为乱码
  9. 根据密码器的初始化方式--加密:将数据加密
  10. 将加密后的数据转换为字符串

    这里用Base64Encoder中会找不到包

    解决办法:

    在项目的Build path中先移除JRE System Library,再添加库JRE System Library,重新编译后就一切正常了。
  11. 将字符串返回

效果演示及代码

效果图

代码

AesJM.java


package AesMmx; import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder; public class AesJM { public static String MmxEncode(String theKey, String theText) {
try {
KeyGenerator k = KeyGenerator.getInstance("AES");//密钥生成器
k.init(128, new SecureRandom(theKey.getBytes()));//初始化128位生成器
SecretKey ori_key = k.generateKey();//产生密钥
byte[] sz = ori_key.getEncoded();//密钥转为二进制数组
SecretKey key = new SecretKeySpec(sz, "AES");//转为AES密钥
Cipher c = Cipher.getInstance("AES");//定义AES密码器
c.init(Cipher.ENCRYPT_MODE, key);//传入密码初始化密码器
byte[] content_b = theText.getBytes("utf-8");//获取文本的utf-8二进制数组
byte[] miwen_b = c.doFinal(content_b);//加密
String miwen = new String(new BASE64Encoder().encode(miwen_b));//加密后的二进制转为String
return miwen;
} catch (Exception e) {
e.printStackTrace();
}
return null;
} public static String MmxDncode(String theKey, String theText) throws UnsupportedEncodingException, IOException {
try {
KeyGenerator k = KeyGenerator.getInstance("AES");
k.init(128, new SecureRandom(theKey.getBytes()));
SecretKey ori_key = k.generateKey();
byte[] sz = ori_key.getEncoded();
SecretKey key = new SecretKeySpec(sz, "AES");
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.DECRYPT_MODE, key);
byte[] content_b = new BASE64Decoder().decodeBuffer(theText);
byte[] mingwen_b = c.doFinal(content_b);//解密
String mingwen = new String(mingwen_b, "utf-8");
return mingwen;
} catch (Exception e) {
e.printStackTrace();
}
return null;
} }

Net.java

package AesMmx;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Date;
import java.util.logging.Level;
import java.util.logging.Logger; public class Net {
//网络功能,实现互相传数据功能
private static int po = 6666;
//默认端口号
public static void setPo(int port) { //设置端口号
po = port;
} public static void ListenNet() throws IOException { //监听端口功能,接受数据
while (true) {
ServerSocket serverSocket = new ServerSocket(po); //创建服务器socket
Socket socket = serverSocket.accept(); //监听端口
InputStream is = socket.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader br = new BufferedReader(isr); //输入流
String info = null;
Date time = new Date();
String theTime = "" + time.getTime(); //获取时间戳
File file = new File(theTime + ".txt");
System.out.println(theTime + ".txt"); //收到的信息保存到文件
BufferedWriter bufw = new BufferedWriter(new FileWriter(file));
while ((info = br.readLine()) != null) {
bufw.write(info);
System.out.println("客户端消息" + info);
}
socket.shutdownInput();
bufw.close();
br.close();
isr.close();
is.close();
socket.close();
serverSocket.close();
}
} public static void send(String ip, int ipport, String str) throws IOException {
Socket socket = new Socket(ip, ipport); //创建socket
OutputStream os = socket.getOutputStream();
PrintWriter pw = new PrintWriter(os); //输出流
pw.write(str); //将数据写出
pw.flush();
socket.shutdownOutput();
pw.close();
os.close();
socket.close();
} public void run(int port) {
while (true) {
try {
ListenNet(); //一直监听
} catch (IOException ex) {
Logger.getLogger(Net.class.getName()).log(Level.SEVERE, null, ex);
}
}
}
}

GUI主要组件:

        jPanel1 = new javax.swing.JPanel();
jPanel2 = new javax.swing.JPanel();
jLabel2 = new javax.swing.JLabel();
dstIP = new javax.swing.JTextField(); //目的IP框
dstPort = new javax.swing.JTextField(); //目的IP端口框
send = new javax.swing.JButton(); //发送按钮
jLabel3 = new javax.swing.JLabel();
lisPort = new javax.swing.JTextField(); //监听端口框
listen = new javax.swing.JButton(); //监听按钮
jPanel3 = new javax.swing.JPanel();
miyue = new javax.swing.JPasswordField(); //密码框
jLabel1 = new javax.swing.JLabel();
jSeparator1 = new javax.swing.JSeparator();
jScrollPane1 = new javax.swing.JScrollPane();
content = new javax.swing.JTextArea(); //文本框
jSeparator2 = new javax.swing.JSeparator();
jPanel4 = new javax.swing.JPanel();
jButton1 = new javax.swing.JButton();
jButton2 = new javax.swing.JButton();
menulist = new javax.swing.JMenuBar(); //菜单栏
jMenu3 = new javax.swing.JMenu(); //文件按钮
open = new javax.swing.JMenuItem(); //打开文件
save = new javax.swing.JMenuItem(); //保存文件
keyMenu = new javax.swing.JMenu(); //密码按钮
openKey = new javax.swing.JMenuItem(); //打开密码
saveKey = new javax.swing.JMenuItem(); //保存密码

MmxGui.java

package AesMmx;

import java.awt.FileDialog;
import java.awt.Frame;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger; public class MmxGui extends javax.swing.JFrame {
//图形界面
private Frame f; //窗体
private File file; //windows文件 public MmxGui() {
initComponents(); //初始化
} private void initComponents() { jPanel1 = new javax.swing.JPanel();
jPanel2 = new javax.swing.JPanel();
jLabel2 = new javax.swing.JLabel();
dstIP = new javax.swing.JTextField(); //目的IP框
dstPort = new javax.swing.JTextField(); //目的IP端口框
send = new javax.swing.JButton(); //发送按钮
jLabel3 = new javax.swing.JLabel();
lisPort = new javax.swing.JTextField(); //监听端口框
listen = new javax.swing.JButton(); //监听按钮
jPanel3 = new javax.swing.JPanel();
miyue = new javax.swing.JPasswordField(); //密码框
jLabel1 = new javax.swing.JLabel();
jSeparator1 = new javax.swing.JSeparator();
jScrollPane1 = new javax.swing.JScrollPane();
content = new javax.swing.JTextArea(); //文本框
jSeparator2 = new javax.swing.JSeparator();
jPanel4 = new javax.swing.JPanel();
jButton1 = new javax.swing.JButton();
jButton2 = new javax.swing.JButton();
menulist = new javax.swing.JMenuBar(); //菜单栏
jMenu3 = new javax.swing.JMenu(); //文件按钮
open = new javax.swing.JMenuItem(); //打开文件
save = new javax.swing.JMenuItem(); //保存文件
keyMenu = new javax.swing.JMenu(); //密码按钮
openKey = new javax.swing.JMenuItem(); //打开密码
saveKey = new javax.swing.JMenuItem(); //保存密码 setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
setTitle("AES加密解密-CJB"); jPanel2.setBorder(javax.swing.BorderFactory.createEtchedBorder()); jLabel2.setFont(new java.awt.Font("等线 Light", 0, 24));
jLabel2.setText("目的IP");
jPanel2.add(jLabel2); dstIP.setFont(new java.awt.Font("等线 Light", 0, 24));
dstIP.setText("127.0.0.1");
dstIP.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
dstIPActionPerformed(evt);
}
});
jPanel2.add(dstIP); dstPort.setFont(new java.awt.Font("等线 Light", 0, 24));
dstPort.setText("6666");
jPanel2.add(dstPort); send.setFont(new java.awt.Font("等线 Light", 0, 24));
send.setText("发送");
send.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
sendActionPerformed(evt);
}
});
jPanel2.add(send); jLabel3.setFont(new java.awt.Font("等线 Light", 0, 24));
jLabel3.setText("监听端口");
jPanel2.add(jLabel3); lisPort.setFont(new java.awt.Font("等线 Light", 0, 24));
lisPort.setText("6666");
jPanel2.add(lisPort); listen.setFont(new java.awt.Font("等线 Light", 0, 24));
listen.setText("开启监听");
listen.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
listenActionPerformed(evt);
}
});
jPanel2.add(listen); jPanel3.setBorder(javax.swing.BorderFactory.createEtchedBorder()); miyue.setFont(new java.awt.Font("等线 Light", 0, 24));
miyue.addKeyListener(new java.awt.event.KeyAdapter() {
public void keyPressed(java.awt.event.KeyEvent evt) {
miyueKeyPressed(evt);
}
}); jLabel1.setFont(new java.awt.Font("等线 Light", 0, 24));
jLabel1.setText("密码"); content.setColumns(20);
content.setRows(5);
jScrollPane1.setViewportView(content); jPanel4.setBorder(javax.swing.BorderFactory.createEtchedBorder()); jButton1.setFont(new java.awt.Font("等线 Light", 0, 24));
jButton1.setText("加密");
jButton1.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton1ActionPerformed(evt);
}
});
jPanel4.add(jButton1); jButton2.setFont(new java.awt.Font("等线 Light", 0, 24));
jButton2.setText("解密");
jButton2.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton2ActionPerformed(evt);
}
});
jPanel4.add(jButton2); javax.swing.GroupLayout jPanel3Layout = new javax.swing.GroupLayout(jPanel3);
jPanel3.setLayout(jPanel3Layout);
jPanel3Layout.setHorizontalGroup(
jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(jPanel3Layout.createSequentialGroup()
.addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel3Layout.createSequentialGroup()
.addContainerGap()
.addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
.addComponent(jSeparator1)
.addGroup(jPanel3Layout.createSequentialGroup()
.addComponent(jLabel1, javax.swing.GroupLayout.PREFERRED_SIZE, 115, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(miyue))))
.addGroup(jPanel3Layout.createSequentialGroup()
.addGap(128, 128, 128)
.addComponent(jScrollPane1))
.addGroup(jPanel3Layout.createSequentialGroup()
.addContainerGap()
.addComponent(jSeparator2))
.addGroup(jPanel3Layout.createSequentialGroup()
.addContainerGap()
.addComponent(jPanel4, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
.addContainerGap())
);
jPanel3Layout.setVerticalGroup(
jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(jPanel3Layout.createSequentialGroup()
.addContainerGap()
.addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(miyue, javax.swing.GroupLayout.PREFERRED_SIZE, 42, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(jLabel1, javax.swing.GroupLayout.PREFERRED_SIZE, 42, javax.swing.GroupLayout.PREFERRED_SIZE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jSeparator1, javax.swing.GroupLayout.PREFERRED_SIZE, 10, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 162, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jSeparator2, javax.swing.GroupLayout.PREFERRED_SIZE, 10, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jPanel4, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addContainerGap(14, Short.MAX_VALUE))
); javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1);
jPanel1.setLayout(jPanel1Layout);
jPanel1Layout.setHorizontalGroup(
jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel1Layout.createSequentialGroup()
.addContainerGap()
.addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
.addComponent(jPanel3, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addComponent(jPanel2, javax.swing.GroupLayout.DEFAULT_SIZE, 637, Short.MAX_VALUE))
.addContainerGap())
);
jPanel1Layout.setVerticalGroup(
jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(jPanel1Layout.createSequentialGroup()
.addContainerGap()
.addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jPanel3, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
); getContentPane().add(jPanel1, java.awt.BorderLayout.CENTER); jMenu3.setText("文件"); open.setText("打开");
open.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
openActionPerformed(evt);
}
});
jMenu3.add(open); save.setText("保存");
save.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
saveActionPerformed(evt);
}
});
jMenu3.add(save); menulist.add(jMenu3); keyMenu.setText("密码"); openKey.setText("导入");
openKey.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
openKeyActionPerformed(evt);
}
});
keyMenu.add(openKey); saveKey.setText("导出");
saveKey.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
saveKeyActionPerformed(evt);
}
});
keyMenu.add(saveKey); menulist.add(keyMenu); setJMenuBar(menulist); pack();
} private void dstIPActionPerformed(java.awt.event.ActionEvent evt) { } private void openActionPerformed(java.awt.event.ActionEvent evt) { f = new Frame("文件浏览");
f.setBounds(300, 100, 650, 600);
openDia = new FileDialog(f, "打开", FileDialog.LOAD); openDia.setVisible(true); String dirpath = openDia.getDirectory();
String fileName = openDia.getFile(); if (dirpath == null || fileName == null)
{
return;
} else {
content.setText(null);
}
File file = new File(dirpath, fileName); try {
BufferedReader bufr = new BufferedReader(new FileReader(file));
String line = null;
while ((line = bufr.readLine()) != null) {
content.append(line + "\r\n");
}
bufr.close();
} catch (FileNotFoundException e1) { e1.printStackTrace();
} catch (IOException e1) { e1.printStackTrace();
}
} private void sendActionPerformed(java.awt.event.ActionEvent evt) {
try { Net.send(dstIP.getText(), Integer.parseInt(dstPort.getText()), content.getText());
} catch (IOException ex) {
Logger.getLogger(MmxGui.class.getName()).log(Level.SEVERE, null, ex);
}
} private void listenActionPerformed(java.awt.event.ActionEvent evt) { Net.setPo(Integer.parseInt(lisPort.getText()));
Runnable r = () -> {
try {
Net.ListenNet();
} catch (IOException ex) {
Logger.getLogger(MmxGui.class.getName()).log(Level.SEVERE, null, ex);
}
};
new Thread(r).start();
} @SuppressWarnings("deprecation")
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) { content.setText(AesJM.MmxEncode(miyue.getText(), content.getText()));
} @SuppressWarnings("deprecation")
private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
try { content.setText(AesJM.MmxDncode(miyue.getText(), content.getText()));
} catch (IOException ex) {
Logger.getLogger(MmxGui.class.getName()).log(Level.SEVERE, null, ex);
}
} private void saveActionPerformed(java.awt.event.ActionEvent evt) { saveDia = new FileDialog(f, "保存", FileDialog.SAVE);
if (file == null) {
saveDia.setVisible(true);
String dirpath = saveDia.getDirectory();
String fileName = saveDia.getFile(); if (dirpath == null || fileName == null)
{
return;
} else {
file = new File(dirpath, fileName);
}
}
try {
BufferedWriter bufw = new BufferedWriter(new FileWriter(file)); String text = content.getText();
bufw.write(text); bufw.close();
} catch (IOException e1) { e1.printStackTrace();
}
} private void miyueKeyPressed(java.awt.event.KeyEvent evt) { } private void openKeyActionPerformed(java.awt.event.ActionEvent evt) { f = new Frame("密码浏览");
f.setBounds(300, 100, 650, 600);
openDia = new FileDialog(f, "打开", FileDialog.LOAD); openDia.setVisible(true); String dirpath = openDia.getDirectory();
String fileName = openDia.getFile();
if (dirpath == null || fileName == null)
{
return;
} else {
miyue.setText(null);
}
File file = new File(dirpath, fileName); try {
BufferedReader bufr = new BufferedReader(new FileReader(file));
String line = null;
while ((line = bufr.readLine()) != null) {
miyue.setText(line);
}
bufr.close();
} catch (FileNotFoundException e1) { e1.printStackTrace();
} catch (IOException e1) { e1.printStackTrace();
}
} @SuppressWarnings("deprecation")
private void saveKeyActionPerformed(java.awt.event.ActionEvent evt) { saveDia = new FileDialog(f, "保存", FileDialog.SAVE);
if (file == null) {
saveDia.setVisible(true);
String dirpath = saveDia.getDirectory();
String fileName = saveDia.getFile(); if (dirpath == null || fileName == null)
{
return;
} else {
file = new File(dirpath, fileName);
}
}
try {
BufferedWriter bufw = new BufferedWriter(new FileWriter(file)); String text = miyue.getText();
bufw.write(text); bufw.close();
} catch (IOException e1) { e1.printStackTrace();
}
} public static void main(String args[]) { try {
for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
if ("Nimbus".equals(info.getName())) {
javax.swing.UIManager.setLookAndFeel(info.getClassName());
break;
}
}
} catch (ClassNotFoundException ex) {
java.util.logging.Logger.getLogger(MmxGui.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (InstantiationException ex) {
java.util.logging.Logger.getLogger(MmxGui.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (IllegalAccessException ex) {
java.util.logging.Logger.getLogger(MmxGui.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (javax.swing.UnsupportedLookAndFeelException ex) {
java.util.logging.Logger.getLogger(MmxGui.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
new MmxGui().setVisible(true);
}
});
}
private FileDialog openDia, saveDia; //windows文件 private javax.swing.JTextArea content;
private javax.swing.JTextField dstIP;
private javax.swing.JTextField dstPort;
private javax.swing.JButton jButton1;
private javax.swing.JButton jButton2;
private javax.swing.JLabel jLabel1;
private javax.swing.JLabel jLabel2;
private javax.swing.JLabel jLabel3;
private javax.swing.JMenu jMenu3;
private javax.swing.JPanel jPanel1;
private javax.swing.JPanel jPanel2;
private javax.swing.JPanel jPanel3;
private javax.swing.JPanel jPanel4;
private javax.swing.JScrollPane jScrollPane1;
private javax.swing.JSeparator jSeparator1;
private javax.swing.JSeparator jSeparator2;
private javax.swing.JMenu keyMenu;
private javax.swing.JTextField lisPort;
private javax.swing.JButton listen;
private javax.swing.JMenuBar menulist;
private javax.swing.JPasswordField miyue;
private javax.swing.JMenuItem open;
private javax.swing.JMenuItem openKey;
private javax.swing.JMenuItem save;
private javax.swing.JMenuItem saveKey;
private javax.swing.JButton send; }

小结(2018.6)

这次实验需要完成:图形界面、打开保存文件、网络传输、AES加密解密。其中,最难的部分是AES加密解密算法的实现,需要我们参考Java文档,查询相关加密、解密内容,同时需要我们合理的应用内置类实现加密解密功能。打开、保存文件是另外一个难点。我查阅相关资料,主要是用如下图实现:

保存和打开文件的过程我是使用字符打开,未实现用二进制保存和打开,且部分格式保存会使其成为无效文件。网络功能主要是应用服务器socket和客户端socket实现。用多线程开启服务器监听,当需要发送信息时创建客户端socket进行通信。GUI部分,因为是用netbeans工具,隐藏隐秘信息的文本框利用如下对象实现:

经过这次实验,我对密码学中的加密、解密原理有更深的认识和研究,也体会到密码学与现实生活的结合、应用。

Java AES加密解密工具 -- GUI 、在线传输文件的更多相关文章

  1. java AES 加密解密工具(Advanced Encryption Standard)发现明文相同但每次重启服务后密文就会不同于是有了改进

    1.通用方法 package com.qlkj.hzd.commom.utils; import javax.crypto.*; import java.io.UnsupportedEncodingE ...

  2. 你真的了解字典(Dictionary)吗? C# Memory Cache 踩坑记录 .net 泛型 结构化CSS设计思维 WinForm POST上传与后台接收 高效实用的.NET开源项目 .net 笔试面试总结(3) .net 笔试面试总结(2) 依赖注入 C# RSA 加密 C#与Java AES 加密解密

    你真的了解字典(Dictionary)吗?   从一道亲身经历的面试题说起 半年前,我参加我现在所在公司的面试,面试官给了一道题,说有一个Y形的链表,知道起始节点,找出交叉节点.为了便于描述,我把上面 ...

  3. C# 实现 JAVA AES加密解密[原创]

    以下是网上普遍能收到的JAVA AES加密解密方法. 因为里面用到了KeyGenerator 和 SecureRandom,但是.NET 里面没有这2个类.无法使用安全随机数生成KEY. 我们在接收J ...

  4. AES加密解密工具类封装(AESUtil)

    package club.codeapes.common.utils; import org.springframework.util.Base64Utils; import javax.crypto ...

  5. C#与Java AES 加密解密

    参考文档:https://www.cnblogs.com/xbzhu/p/7064642.html 前几天对接Java接口,需要C#加密参数,Java解密.奈何网上找了一堆大同小异的加解密方法都跟Ja ...

  6. JAVA AES加密解密

    import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java ...

  7. 自写AES加密解密工具类

    此类主要用于加密与解密,采用128位ECB模式,PKCS5Padding填充补位. 可使用方法为加密返回二进制encryptBin(content, key).加密返回十六进制encryptHex(c ...

  8. java中加密解密工具类

    在工作中经常遇到需要加密.解密的场景.例如用户的手机号等信息,在保存到数据库的过程中,需要对数据进行加密.取出时进行解密. public class DEStool { private String ...

  9. Java 关于密码处理的工具类[MD5编码][AES加密/解密]

    项目中又遇到了加密问题,又去翻了半天,然后做测试,干脆就把常用的两类小结一下. 1.第一种所谓的MD5加密 其实也不算加密,只是基于Hash算法的不可逆编码而已,等于说,一旦经过MD5处理,是不可能从 ...

随机推荐

  1. ffmpeg命令操作音频格式转换

    1.转MP3为wav ffmpeg -i input.mp3 -acodec pcm_s16le -ac 2 -ar 44100 output.wav 2.转m4a为wav ffmpeg -i inp ...

  2. Java 基础类库

    与用户互动 1. 运行java程序的参数 public static void main(Stirng[] args) 这个方法是有JVM调用,因此用public static修饰,并且没有返回值,同 ...

  3. Windows快捷键应用

    键盘上每个键作用 F1--------------辅助 F3--------------搜索 F4--------------地址 F5--------------刷新 F6------------- ...

  4. k8s的nfs存储外挂设置过程

    需求: 在k8s集群里的某个模块生成的目录文件或者更新的目录文件,存储到外面某台服务器上 1.安装nfs服务(192.168.1.2  Ubuntu 16.04) apt-get install nf ...

  5. JavaSE---ThreadLocal

    1.Java为线程安全提供了工具类,如ThreadLocal等: 2.ThreadLocal类是一个   线程局部变量  ,通过将  ”数据“  放在ThreadLocal中,即可在每条线程中创建一个 ...

  6. Spark Mllib里如何记录开始训练时间、完成训练时间、所需训练时间(图文详解)

    不多说,直接上干货! 具体,见 Hadoop+Spark大数据巨量分析与机器学习整合开发实战的第16章 朴素贝叶斯二元分类算法来预测分类StumbleUpon数据集

  7. Redis 基础特性讲解

    目录 1.Redis基础杂项小节 1.是什么 2.能干嘛 3.去哪下 4.Redis启动后基础知识讲解 2.Redis数据类型 1.常用的五大数据类型 2.高级'玩家'才知道的其他数据类型 3.Red ...

  8. 《从0到1学习Flink》—— 如何自定义 Data Source ?

    前言 在 <从0到1学习Flink>-- Data Source 介绍 文章中,我给大家介绍了 Flink Data Source 以及简短的介绍了一下自定义 Data Source,这篇 ...

  9. Windows1

    ① 对Windows的设置一般在, 所有设置, 控制面板(control), 管理方式打开此电脑和此电脑上的选项 ② 关闭对账号安全的检验, 在控制面板中, 找到系统和安全, 再找到更改用户账号控制设 ...

  10. Android仿360悬浮小球自定义view实现

    转载请标明出处:http://www.jianshu.com/u/a5ad093cffe8 效果图如下: 图片.png   图片.png 实现当前这种类似的效果 (360小球 悬浮桌面差不错类似).第 ...