1、android jni實現
1.靜態實現jni:先由Java獲得本地方法的聲明,而後再經過JNI實現該聲明方法。
2.動態實現jni:先經過JNI重載JNI_OnLoad()實現本地方法,而後直接在Java中調用本地方法。html
採用靜態實現的方式,若是沒有進行加密處理,很容易就在IDA導出函數搜到
採用動態實現的方式,還能起到必定的隱藏做用,導出的部分不是就能直接看到java層調的函數名,而是綁定的函數名java
native層:
在JNI_OnLoad註冊相關函數android
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();
2、Android中調用Arm彙編代碼spa
Android.mk文件.net
# This file is jni/Android.mk LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_ARM_MODE := arm # Name of the local module LOCAL_MODULE := hello-jni # The files that make up the source code LOCAL_SRC_FILES := hello-jni.c multiple.s include $(BUILD_SHARED_LIBRARY)
multiple.s符合gnu語法code
@ This file is jni/multiple.s .text .align 2 .global armFunction .type armFunction, %function armFunction: @ Multiply by 10. Input value and return value in r0 stmfd sp!, {fp,ip,lr} mov r3, r0, asl #3 add r0, r3, r0, asl #1 ldmfd sp!, {fp,ip,lr} bx lr .size armFunction, .-armFunction
直接調用在c中armFunction(input)調用htm
3、參考:
http://www.cnblogs.com/skywang12345/archive/2013/05/23/3095074.html
http://www.cnblogs.com/skywang12345/archive/2013/05/23/3092491.html
http://my.oschina.net/redhouse/blog/101375
http://blog.csdn.net/dndxhej/article/details/7515949blog