-
定义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
相关推荐
MengYiKeNan5 分钟前
C++二分函数lower_bound和upper_bound的用法戊子仲秋24 分钟前
【LeetCode】每日一题 2024_9_19 最长的字母序连续子字符串的长度(字符串,双指针)小林熬夜学编程41 分钟前
C++第五十一弹---IO流实战:高效文件读写与格式化输出蠢蠢的打码1 小时前
8584 循环队列的基本操作Good_tea_h1 小时前
Android中的单例模式程序猿进阶3 小时前
如何在 Visual Studio Code 中反编译具有正确行号的 Java 类?Eloudy3 小时前
一个编写最快,运行很慢的 cuda gemm kernel, 占位 kernelking_machine design3 小时前
matlab中如何进行强制类型转换西北大程序猿4 小时前
C++ (进阶) ─── 多态无名之逆4 小时前
云原生(Cloud Native)