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加密有这么多问题,感觉很坑,目前测试了各种机型和系统,暂时没有遇到有报错或者崩溃的机子。关于加密就暂时先写到这里,如果有遇到类似问题的同学可以参考,后面要学习下原理.