-
定义JNI方法
companion object{ init { System.loadLibrary("jnitest") } } external fun encryptAES(data :ByteArray): ByteArray? external fun decryptAES(data :ByteArray): ByteArray?
-
使用OpenSSL方法实现AES加密和解密
#include "include/openssl/aes.h" const char* key_data = "0123456789abcdef"; extern "C" JNIEXPORT jbyteArray JNICALL Java_com_test_jnitest_TestLib_encryptAES(JNIEnv *env, jobject thiz, jbyteArray data_) { size_t len = strlen(key_data); // 数据长度 unsigned char* unsigned_key_data = new unsigned char[len]; // 分配内存空间 // 将数据复制到内存空间中 memcpy(unsigned_key_data, key_data, len); jbyte *data = env->GetByteArrayElements( data_, NULL); jsize data_length = env->GetArrayLength( data_); // 创建 AES 上下文对象 AES_KEY aes_key; if (AES_set_encrypt_key(unsigned_key_data, len * 8, &aes_key) < 0) { return NULL; } // 分配加密结果缓冲区 int out_size = data_length + AES_BLOCK_SIZE; unsigned char *encrypted_data = (unsigned char *) malloc(out_size); if (encrypted_data == NULL) { return NULL; } // 执行加密操作 AES_cbc_encrypt((unsigned char *) data, encrypted_data, data_length, &aes_key, unsigned_key_data, AES_ENCRYPT); // 将加密结果转换为 Java 中的 byte 数组返回 jbyteArray result = env->NewByteArray( out_size); env->SetByteArrayRegion( result, 0, out_size, (jbyte *) encrypted_data); // 释放内存 free(encrypted_data); env->ReleaseByteArrayElements( data_, data, JNI_ABORT); return result; } extern "C" JNIEXPORT jbyteArray JNICALL Java_com_test_jnitest_TestLib_decryptAES(JNIEnv *env, jobject thiz, jbyteArray data_) { size_t len = strlen(key_data); // 数据长度 unsigned char* unsigned_key_data = new unsigned char[len]; // 分配内存空间 // 将数据复制到内存空间中 memcpy(unsigned_key_data, key_data, len); jbyte *data = env->GetByteArrayElements( data_, NULL); jsize data_length = env->GetArrayLength( data_); // 创建 AES 上下文对象 AES_KEY aes_key; if (AES_set_decrypt_key(unsigned_key_data, len * 8, &aes_key) < 0) { return NULL; } // 分配解密结果缓冲区 int out_size = data_length - AES_BLOCK_SIZE; unsigned char *decrypted_data = (unsigned char *) malloc(out_size); if (decrypted_data == NULL) { return NULL; } // 执行解密操作 AES_cbc_encrypt((unsigned char *) data, decrypted_data, data_length, &aes_key, unsigned_key_data, AES_DECRYPT); // 将解密结果转换为 Java 中的 byte 数组返回 jbyteArray result = env->NewByteArray( out_size); env->SetByteArrayRegion( result, 0, out_size, (jbyte *) decrypted_data); // 释放内存 free(decrypted_data); env->ReleaseByteArrayElements( data_, data, JNI_ABORT); return result; }
-
应用
var testLib = TestLib() var encrpy = testLib.encryptAES("HelloWorld!!!!!!".toByteArray()) encrpy?.let { var decrpy = testLib.decryptAES(it) decrpy?.let { Log.i(TAG, String(it)) } }
Android集成OpenSSL实现加解密-JNI实现
菠萝加点糖2024-01-01 5:05
相关推荐
大怪v2 小时前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!CYRUS_STUDIO2 小时前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析CYRUS_STUDIO2 小时前
Frida 实战:Android JNI 数组 (jobjectArray) 操作全流程解析惯导马工4 小时前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and骑自行车的码农5 小时前
【React用到的一些算法】游标和栈用户095 小时前
Gradle Cache Entries 深度探索博笙困了5 小时前
AcWing学习——双指针算法循环不息优化不止6 小时前
安卓 View 绘制机制深度解析叽哥6 小时前
Kotlin学习第 9 课:Kotlin 实战应用:从案例到项目moonlifesudo6 小时前
322:零钱兑换(三种方法)