-
定义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
相关推荐
XH华29 分钟前
初识C语言之二维数组(下)南宫生1 小时前
力扣-图论-17【算法学习day.67】拭心1 小时前
Google 提供的 Android 端上大模型组件:MediaPipe LLM 介绍不想当程序猿_1 小时前
【蓝桥杯每日一题】求和——前缀和落魄君子1 小时前
GA-BP分类-遗传算法(Genetic Algorithm)和反向传播算法(Backpropagation)菜鸡中的奋斗鸡→挣扎鸡1 小时前
滑动窗口 + 算法复习Lenyiin2 小时前
第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ郭wes代码2 小时前
Cmd命令大全(万字详细版)scan7242 小时前
LILAC采样算法菌菌的快乐生活2 小时前
理解支持向量机