这是网站工具实现的加密,各个参数是什么作用大家可以自己去百度,接下来我就贴上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")) }
}