案例:
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
public class AESExample {
private static final String SECRET_KEY = “ThisIsASecretKey”; // 16, 24, or 32 bytes long
public static String encrypt(String data) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(SECRET_KEY.getBytes(StandardCharsets.UTF_8), “AES”);
Cipher cipher = Cipher.getInstance(“AES/ECB/PKCS5Padding”);
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
byte[] encryptedBytes = cipher.doFinal(data.getBytes(StandardCharsets.UTF_8));
return Base64.getEncoder().encodeToString(encryptedBytes);
}
public static String decrypt(String encryptedData) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(SECRET_KEY.getBytes(StandardCharsets.UTF_8), “AES”);
Cipher cipher = Cipher.getInstance(“AES/ECB/PKCS5Padding”);
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
byte[] decryptedBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedData));
return new String(decryptedBytes, StandardCharsets.UTF_8);
}
public static void main(String[] args) {
try {
String originalData = “Hello, this is a secret message!”;
String encryptedData = encrypt(originalData);
String decryptedData = decrypt(encryptedData);
System.out.println("Original Data: " + originalData);
System.out.println("Encrypted Data: " + encryptedData);
System.out.println("Decrypted Data: " + decryptedData);
} catch (Exception e) {
e.printStackTrace();
}
}
}
案例讲解:
1、初始化密钥:
private static final String SECRET_KEY = “ThisIsASecretKey”;
我们定义了一个用于AES加密和解密的密钥。请注意,在实际应用中,应该使用更安全的方法生成和管理密钥,并避免在源代码中硬编码密钥。
2、加密方法:
public static String encrypt(String data) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(SECRET_KEY.getBytes(StandardCharsets.UTF_8), “AES”);
Cipher cipher = Cipher.getInstance(“AES/ECB/PKCS5Padding”);
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
byte[] encryptedBytes = cipher.doFinal(data.getBytes(StandardCharsets.UTF_8));
return Base64.getEncoder().encodeToString(encryptedBytes);
}
在encrypt
方法中,我们以明文数据(字符串)作为输入,使用AES执行加密。以下是步骤的详细解释:
- 我们将
SECRET_KEY
字符串转换为SecretKeySpec
对象,这是执行AES加密所需的对象。我们使用getBytes
方法将密钥字符串转换为字节数组,并指定UTF-8字符编码。 - 我们使用
Cipher.getInstance("AES/ECB/PKCS5Padding")
创建AESCipher
实例。参数"AES/ECB/PKCS5Padding"
指定了加密算法(AES)、操作模式(ECB)和填充方案(PKCS5Padding)。请注意,此处使用ECB模式是为了简单起见,但在实际应用中,应该优先使用带有初始化向量(IV)的CBC模式,以提供更好的安全性。 - 我们使用
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec)
方法初始化加密的Cipher
实例,传入Cipher.ENCRYPT_MODE
模式和之前创建的SecretKeySpec
。 - 我们使用
cipher.doFinal(data.getBytes(StandardCharsets.UTF_8))
加密明文数据,该方法返回加密后的数据字节数组。 - 最后,我们使用
Base64.getEncoder().encodeToString(encryptedBytes)
将加密后的字节数组转换为Base64编码的字符串,并返回它。
3、解密方法:
public static String decrypt(String encryptedData) throws Exception {
SecretKeySpec secretKeySpec = new SecretKeySpec(SECRET_KEY.getBytes(StandardCharsets.UTF_8), “AES”);
Cipher cipher = Cipher.getInstance(“AES/ECB/PKCS5Padding”);
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
byte[] decryptedBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedData));
return new String(decryptedBytes, StandardCharsets.UTF_8);
}
decrypt
方法接收Base64编码的加密数据作为输入,并使用AES执行解密过程。以下是它的工作原理:
- 我们创建
SecretKeySpec
对象,使用与加密方法相同的SECRET_KEY
字符串和UTF-8编码。 - 我们使用与加密方法相同的参数创建AES
Cipher
实例。 - 我们使用
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec)
方法初始化解密的Cipher
实例,传入Cipher.DECRYPT_MODE
模式和之前创建的SecretKeySpec
。
本人从事网路安全工作12年,曾在2个大厂工作过,安全服务、售后服务、售前、攻防比赛、安全讲师、销售经理等职位都做过,对这个行业了解比较全面。
最近遍览了各种网络安全类的文章,内容参差不齐,其中不伐有大佬倾力教学,也有各种不良机构浑水摸鱼,在收到几条私信,发现大家对一套完整的系统的网络安全从学习路线到学习资料,甚至是工具有着不小的需求。
最后,我将这部分内容融会贯通成了一套282G的网络安全资料包,所有类目条理清晰,知识点层层递进,需要的小伙伴可以点击下方小卡片领取哦!下面就开始进入正题,如何从一个萌新一步一步进入网络安全行业。
学习路线图
其中最为瞩目也是最为基础的就是网络安全学习路线图,这里我给大家分享一份打磨了3个月,已经更新到4.0版本的网络安全学习路线图。
相比起繁琐的文字,还是生动的视频教程更加适合零基础的同学们学习,这里也是整理了一份与上述学习路线一一对应的网络安全视频教程。
网络安全工具箱
当然,当你入门之后,仅仅是视频教程已经不能满足你的需求了,你肯定需要学习各种工具的使用以及大量的实战项目,这里也分享一份我自己整理的网络安全入门工具以及使用教程和实战。
项目实战
最后就是项目实战,这里带来的是SRC资料&HW资料,毕竟实战是检验真理的唯一标准嘛~
面试题
归根结底,我们的最终目的都是为了就业,所以这份结合了多位朋友的亲身经验打磨的面试题合集你绝对不能错过!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!