1、encrypt.c文件,需要导入jni.h,增加打印,需要导入android/log.h
#include <jni.h>
#include <string.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
#include <fcntl.h>
#include <ctype.h>
#include <linux/fb.h>
#include <sys/mman.h>
#include <memory.h>
#include <android/log.h>
#include "hal_linux_i2c_userspace.h"
#define TAG "Magic" // 这个是自定义的LOG的标识
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,TAG ,__VA_ARGS__) // 定义LOGD类型
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG ,__VA_ARGS__) // 定义LOGI类型
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN,TAG ,__VA_ARGS__) // 定义LOGW类型
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG ,__VA_ARGS__) // 定义LOGE类型
#define LOGF(...) __android_log_print(ANDROID_LOG_FATAL,TAG ,__VA_ARGS__) // 定义LOGF类型
jstring JNICALL
//Java_com_zkteco_i2cutil_MainActivity_stringFromJNI(
Java_com_xuhaoran_factorymode_Encrypt_stringFromJNI(
JNIEnv *env,
jobject jobject) {
char str[20] = "hello from c";
return (*env)->NewStringUTF(env, str);
}
JNIEXPORT jstring JNICALL
Java_com_xuhaoran_factorymode_Encrypt_getSn(JNIEnv *env, jobject thiz) {
unsigned char *sn = malloc(sizeof(unsigned char) * 32);
char *sn_str = malloc(sizeof(char) * 32);
//for (int i = 0; i < 5; i++) {
int ret = run(sn);
if (ret == 0) {
LOGD("read sn success");
convertUnCharToStr(sn_str, sn, 32);
//break;
} else {
//LOGI("read sn failed,try again ,%d", i);
}
//}
return (*env)->NewStringUTF(env, sn_str);
}
JNIEXPORT jint JNICALL
Java_com_xuhaoran_factorymode_Encrypt_getSN(JNIEnv *env, jobject thiz, jbyteArray sn) {
unsigned char *sn_ = malloc(sizeof(unsigned char) * 32);
char *sn_str = malloc(sizeof(char) * 32);
int ret = -1;
for (int i = 0; i < 5; i++) {
ret = run(sn_);
LOGI("read sn ret = %d", ret);
if (ret == 0) {
LOGD("read sn success");
convertUnCharToStr(sn_str, sn_, 32);
break;
} else {
LOGI("read sn failed,try again ,%d", i);
}
}
return ret;
}
2、Android.mk文件
```powershell
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
LOCAL_C_INCLUDES := \
hal_linux_i2c_userspace.h
# LOCAL_CFLAGS := -O3 -DNDEBUG
# LOCAL_CPPFLAGS := -std=gnu++98
LOCAL_SRC_FILES := \
hal_linux_i2c_userspace.c \
encrypt.c
LOCAL_SHARED_LIBRARIES := libandroid_runtime
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -ldl -llog -lGLESv2 -L$(TARGET_OUT)
LOCAL_MODULE_TAGS := optional
LOCAL_MODULE := libjni_encrypt
include $(BUILD_SHARED_LIBRARY)
# include $(BUILD_EXECUTABLE)
include $(call all-makefiles-under, $(LOCAL_PATH))
3、device.mk 文件中增加编译代码
PRODUCT_PACKAGES += libjni_encrypt