一、android jni完成
1.静态完成jni:先由Java得到本地办法的声明,然后再经过JNI完成该声明办法。
2.动态完成jni:先经过JNI重载JNI_OnLoad()完成本地办法,然后直接在Java中调用本地办法。
选用静态完成的办法,假如没有进行加密处理,很简单就在IDA导出函数搜到
选用动态完成的办法,还能起到必定的躲藏效果,导出的部分不是就能直接看到java层调的函数名,而是绑定的函数名
native层:
在JNI_OnLoad注册相关函数
JNIEXPORT jstring JNICALL native_hello(JNIEnv *env, jclass clazz){return (*env)->NewStringUTF(env, "hello load jni.");}
// Java和JNI函数的绑定表
static JNINativeMethod method_table[] = {{ "HelloLoad", "()Ljava/lang/String;", (void*)native_hello },//绑定};
java层:
// jni中注册的办法
public native String HelloLoad();
二、Android中调用Arm汇编代码
Android.mk文件
# This file is jni/Android.mkLOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_ARM_MODE := arm# Name of the local moduleLOCAL_MODULE := hello-jni# The files that make up the source codeLOCAL_SRC_FILES := hello-jni.c multiple.sinclude $(BUILD_SHARED_LIBRARY)
multiple.s契合gnu语法
@ This file is jni/multiple.s.text.align 2.global armFunction.type armFunction, %functionarmFunction:@ Multiply by 10. Input value and return value in r0stmfd sp!, {fp,ip,lr}mov r3, r0, asl #3add r0, r3, r0, asl #1ldmfd sp!, {fp,ip,lr}bx lr.size armFunction, .-armFunction
直接调用在c中armFunction(input)调用