AndroidAES加密2之解决AES加密在Android中报错问题

1.之前使用AES加密解决了9.0系统手机的问题,由于项目周期和设备原因没有调试6.0及6.0以下的设备,加上使用java的Base64加密,其中Java的Base64加密方法在Android8.0及以上使用才有效,属于过时的方法,在6.0及以下系统的手机直接就崩溃了,于是又找到了一种解决方法,不用考虑系统。

 

2.解决AES加密报错的工具类如下:

package com.example.focusimageview.util;

import android.util.Base64;

import java.nio.charset.StandardCharsets;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;

import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.spec.SecretKeySpec;

/**
 * 秘钥必须为16位字符串
 */
public class AESUtils {

    private static final String ALGORITHM_AES = "AES/ECB/PKCS5Padding";

    public static String Encrypt(String sSrc, String sKey) {
        try {
            byte[] raw = sKey.getBytes(StandardCharsets.UTF_8);
            SecretKeySpec key = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance(ALGORITHM_AES);//"算法/模式/补码方式"
            cipher.init(Cipher.ENCRYPT_MODE, key);
            byte[] encrypted = cipher.doFinal(sSrc.getBytes(StandardCharsets.UTF_8));
            //此处使用BASE64做转码功能,同时能起到2次加密的作用。
            return Base64.encodeToString(encrypted, Base64.NO_WRAP);
        } catch (NoSuchAlgorithmException | InvalidKeyException | NoSuchPaddingException | BadPaddingException | IllegalBlockSizeException e) {
            e.printStackTrace();
        }
        return "";
    }

    public static String Decrypt(String sSrc, String sKey) {
        try {
            byte[] raw = sKey.getBytes(StandardCharsets.UTF_8);
            SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance(ALGORITHM_AES);
            cipher.init(Cipher.DECRYPT_MODE, skeySpec);
            //先用base64解密
            byte[] encrypted1 = Base64.decode(sSrc, Base64.NO_WRAP);
            byte[] original = cipher.doFinal(encrypted1);
            return new String(original, StandardCharsets.UTF_8);
        } catch (Exception ex) {
            throw new RuntimeException(ex);
        }
    }
}

3.使用方法如下:

打印出来的日志结果如下:加解密结果一致,而且在各种手机系统上都正常,换了一种加密的类型.

4.之前加密都是用的md5和base64,第一次遇到AES加密有这么多问题,感觉很坑,目前测试了各种机型和系统,暂时没有遇到有报错或者崩溃的机子。关于加密就暂时先写到这里,如果有遇到类似问题的同学可以参考,后面要学习下原理. 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值