您当前的位置:首页 > 计算机 > 加密解密

AES加密

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

网站工具实现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")) }

}
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门