新聞中心

arm匯編學(xué)習(xí)(四)

作者: 時(shí)間:2016-11-09 來(lái)源:網(wǎng)絡(luò) 收藏
一、android jni實(shí)現(xiàn)

1.靜態(tài)實(shí)現(xiàn)jni:先由Java得到本地方法的聲明,然后再通過(guò)JNI實(shí)現(xiàn)該聲明方法。
2.動(dòng)態(tài)實(shí)現(xiàn)jni:先通過(guò)JNI重載JNI_OnLoad()實(shí)現(xiàn)本地方法,然后直接在Java中調(diào)用本地方法。

本文引用地址:http://m.butianyuan.cn/article/201611/317582.htm

采用靜態(tài)實(shí)現(xiàn)的方式,如果沒(méi)有進(jìn)行加密處理,很容易就在IDA導(dǎo)出函數(shù)搜到
采用動(dòng)態(tài)實(shí)現(xiàn)的方式,還能起到一定的隱藏作用,導(dǎo)出的部分不是就能直接看到j(luò)ava層調(diào)的函數(shù)名,而是綁定的函數(shù)名

native層:
在JNI_OnLoad注冊(cè)相關(guān)函數(shù)

JNIEXPORT jstring JNICALL native_hello(JNIEnv *env, jclass clazz){return (*env)->NewStringUTF(env, "hello load jni.");}

// Java和JNI函數(shù)的綁定表

static JNINativeMethod method_table[] = {{ "HelloLoad", "()Ljava/lang/String;", (void*)native_hello },//綁定};


java層:
// jni中注冊(cè)的方法

public native String HelloLoad();


二、Android中調(diào)用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

直接調(diào)用在c中armFunction(input)調(diào)用



關(guān)鍵詞: arm匯編學(xué)

評(píng)論


技術(shù)專(zhuān)區(qū)

關(guān)閉