【工具类】JAVA (Android Studio )+ JS 加密解密 AES + Base 64

JAVA (Android Studio )+ JS 加密解密 AES + Base 64

前言

整个过程:

  • JS 接口先用AES加密,然后加密内容转Base64 编码;
  • JAVA进行Base64解码,然后用AES解密。

在这个过程JS用到了 CryptoJS v3.1.2 库;JAVA 由于JDK 17,不需要导入外部 javax.crypto ,由于存在Base 64 解码过程,import java.util.Base64; 的使用要求minSdk 是26,也就是Android 8.0

在使用AES 加解密过程中,最头疼的就是AES解密后是字节数组,如果转String ,或者String转字节数组,会加解密失败,究其原因,主要是 getBytes()new String() 有一个编码规则的问题,需要指定,因此索性直接再加一层Base 64。

还有一个问题是,看网上说JAVA 中 填充方式 在JDK 8前不支持 PKCS7Padding ,JDK 8 后就有 。由于是JDK17,所以PKCS5Padding 和PKCS7Padding 都可以使用。但看了网上的介绍,其实pkcs5在AES中是不可以使用的,通常我们在AES中所说的pkcs5指的就是pkcs7 。所以为了避免代码在JDK8报错,而且只用了ASE算法,索性解密设置时也采用PKCS5Padding,JS加密用PKCS7Padding。当然啦,也可以导入bcprov-ext-jdk16来支持PKCS7Padding。

用得第三方测试工具,进行ASE +Base 64 加解密验证,设置AES/CBC/PKCS7Padding。

JAVA 代码(解密)

java 复制代码
private String KEY ="密钥";
private String IV ="偏移量";
java 复制代码
try {
				String encryptUrl ="加密网址";
                byte[] decodedBytes = Base64.getDecoder().decode(encryptUrl);
                Cipher cipher =Cipher.getInstance("AES/CBC/PKCS5Padding");
                SecretKeySpec secretKeySpec =new SecretKeySpec(KEY.getBytes(),"AES");
                IvParameterSpec ivParameterSpec = new IvParameterSpec(IV.getBytes());
                cipher.init(Cipher.DECRYPT_MODE,secretKeySpec,ivParameterSpec);
                byte[] bytes =cipher.doFinal(decodedBytes);
                String decryptUrl = new String(bytes);
                Log.v("TAG","解密网址:"+decryptUrl);
                Toast.makeText(this,"解密网址:"+decryptUrl,Toast.LENGTH_LONG).show();
                mWebView.loadUrl(decryptUrl);
            }catch (Exception e) {
                Log.e("TAG", "URL解密失败:"+e.getMessage());
                Toast.makeText(this,"URL解密失败:"+e.getMessage(),Toast.LENGTH_LONG).show();
                mWebView.loadUrl("解密失败加载的网址");
            }

JS代码(加密)

javascript 复制代码
function webUrl() {//AES + Base 64
    var url = "需要加密的网址";
    var loadWeb = encrypt(url, "密钥", "偏移量");
    return loadWeb;
}

用到的crypto-js_v3.1.2.js 方法已经上传,下载后将webUrl()方法放入这个就可以调用。用得都是JS语言。

相关推荐
曹牧2 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法3 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7253 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎3 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄3 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
Moment3 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
忆~遂愿3 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
爱敲代码的小鱼3 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
小韩学长yyds4 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化
仟濹4 小时前
【Java基础】多态 | 打卡day2
java·开发语言