arm匯編學(xué)習(四)
1.靜態(tài)實(shí)現jni:先由Java得到本地方法的聲明,然后再通過(guò)JNI實(shí)現該聲明方法。
2.動(dòng)態(tài)實(shí)現jni:先通過(guò)JNI重載JNI_OnLoad()實(shí)現本地方法,然后直接在Java中調用本地方法。
采用靜態(tài)實(shí)現的方式,如果沒(méi)有進(jìn)行加密處理,很容易就在IDA導出函數搜到
采用動(dòng)態(tài)實(shí)現的方式,還能起到一定的隱藏作用,導出的部分不是就能直接看到j(luò )ava層調的函數名,而是綁定的函數名
native層:
在JNI_OnLoad注冊相關(guān)函數
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語(yǔ)法
@ 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)調用
評論