AES加密

65 篇文章 6 订阅
22 篇文章 0 订阅

网站工具实现AES加密

网址:http://tool.chacuo.net/cryptaes
在这里插入图片描述
这是网站工具实现的加密,各个参数是什么作用大家可以自己去百度,接下来我就贴上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")) }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

android_cai_niao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值