2025年3月28日 星期五 甲辰(龙)年 月廿七 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 加密解密

AES加密

时间:02-06来源:作者:点击数:38

网站工具实现AES加密

在这里插入图片描述

这是网站工具实现的加密,各个参数是什么作用大家可以自己去百度,接下来我就贴上Java和Kotlin和Android的实现版本。

Java版本

  • 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版本

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版本(Kotlin)

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")) }
  • }
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门