这是网站工具实现的加密,各个参数是什么作用大家可以自己去百度,接下来我就贴上Java和Kotlin和Android的实现版本。
- import javax.crypto.Cipher;
- import javax.crypto.spec.SecretKeySpec;
- import java.util.Base64;
-
- public class Aes {
-
- public static String encrypt(String rawData) {
- try {
- return Base64.getEncoder().encodeToString(getCipher(Cipher.ENCRYPT_MODE).doFinal(rawData.getBytes()));
- } catch (Exception e) {
- return null;
- }
- }
-
- public static String decrypt(String base64Data) {
- try {
- return new String(getCipher(Cipher.DECRYPT_MODE).doFinal(Base64.getDecoder().decode(base64Data)));
- } catch (Exception e) {
- return null;
- }
- }
-
- public static Cipher getCipher(int mode) {
- try {
- Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
- cipher.init(mode, new SecretKeySpec("abcdefgabcdefg88".getBytes(), "AES"));
- return cipher;
- } catch (Exception e) {
- return null;
- }
- }
-
- }
-
使用:
- public static void main(String[] args) {
- String rawData = "Hello World!";
- String encryptData = Aes.encrypt(rawData);
- String decryptData = Aes.decrypt(encryptData);
-
- System.out.println("原始数据:" + rawData);
- System.out.println("加密数据:" + encryptData);
- System.out.println("解密数据:" + decryptData);
- }
-
Kotlin写代码就是爽啊,不需要写那些无意义的try/catch语句,如下:
注:后来发现,try/catch一下还是有必要的,因为正常的数据加密、解密肯定是没异常的,但是如果数据来源不可靠的话就有可能有异常,如解密:Aes.decrypt(“你好”),这本来就没加密,这解密时会出现异常。
- import java.util.*
- import javax.crypto.Cipher
- import javax.crypto.spec.SecretKeySpec
-
- object Aes {
-
- /** 使用AES进行加密,加密后的数据使用Base64编码为String */
- fun encrypt(rawData: String): String = Base64.getEncoder().encodeToString(getCipher(Cipher.ENCRYPT_MODE).doFinal(rawData.toByteArray()))
-
- /** 把AES加密并通过Base64编码的String进行解密,还原为原始的String */
- fun decrypt(base64Data: String): String = String(getCipher(Cipher.DECRYPT_MODE).doFinal(Base64.getDecoder().decode(base64Data)))
-
- private fun getCipher(mode: Int) = Cipher.getInstance("AES/ECB/PKCS5Padding").apply { init(mode, SecretKeySpec("abcdefgabcdefg88".toByteArray(), "AES")) }
-
- }
-
Android版本的不同点在于Base64,没有java.util.Base64,而是android.util.Base64,用法稍微有点不同,但也差不多,如下:
- import android.util.Base64
- import javax.crypto.Cipher
- import javax.crypto.spec.SecretKeySpec
-
- /** AES加密、解密 */
- object Aes {
-
- /** 使用AES进行加密,加密后的数据使用Base64编码为String */
- fun encrypt(rawData: String): String = Base64.encodeToString(getCipher(Cipher.ENCRYPT_MODE).doFinal(rawData.toByteArray()), Base64.NO_WRAP)
-
- /** 把AES加密并通过Base64编码的String进行解密,还原为原始的String */
- fun decrypt(base64Data: String): String = String(getCipher(Cipher.DECRYPT_MODE).doFinal(Base64.decode(base64Data, Base64.NO_WRAP)))
-
- @SuppressLint("GetInstance")
- private fun getCipher(mode: Int) = Cipher.getInstance("AES/ECB/PKCS5Padding").apply { init(mode, SecretKeySpec("abcdefgabcdefg88".toByteArray(), "AES")) }
-
- }
-