java android log_为android java基础库插入log

近来有一个需求,是需要在android java基础库中插入一些log信息,完成这个工作需要的前置条件有

编译好的android源码

具体android源码如何编译,这里笔者推荐使用cm的android源码,里面的驱动都已经有相应的分支,可以支持大多数的主流机型,关于如何编译cm的android源码,可以参考我以前写的博文,在android system目录中。

android 4.0以后的源码中关于 java基础类库的代码在

libcore/luni/src/main/java

这个目录下

首先找到你要插入log的java基础文件,比如 java.io.File 这个文件为例子,我们想在

public File(String path)

public File(String path) {

Log("cheatecore","File String path = " + path);

this.path = fixSlashes(path);

}

插入这条log,来记录所有的apk对文件操作的记录,由于android.util.Log 这个类并没有定义在java基础类库中所以需要通过jni调用的方式来完成这个任务。

步骤1在File.java 这个文件中添加下面的语句private static final int LOG_ID_MAIN = 0;

private static final int DEBUG = 3;

public static int Log(String tag,String msg)

{

return println_native(LOG_ID_MAIN,DEBUG,tag,msg);

}

private static native int println_native(int bufID,

int priority,String tag,String msg);

步骤2 参考 /Frameworks/base/core/jni/android_util_Log.cpp

这个文件中对于 println_native 这个函数的实现,其实这个文件就是

/Frameworks/base/core/java/android/util/Log.java 这个java文件的

本地化实现,里面自然有 println_native 这个函数的实现,这里我们需要拷贝

这个函数到 /luni/src/main/native/java_io_File.cpp这个文件中static jint android_util_Log_println_native(JNIEnv* env, jobject clazz,

jint bufID, jint priority, jstring tagObj, jstring msgObj)

{

const char* tag = NULL;

const char* msg = NULL;

if (msgObj == NULL) {

jniThrowNullPointerException(env, "println needs a message");

return -1;

}

if (bufID = LOG_ID_MAX) {

jniThrowNullPointerException(env, "bad bufID");

return -1;

}

if (tagObj != NULL)

tag = env->GetStringUTFChars(tagObj, NULL);

msg = env->GetStringUTFChars(msgObj, NULL);

int res = __android_log_buf_write(bufID, (android_LogPriority)priority, tag, msg);

if (tag != NULL)

env->ReleaseStringUTFChars(tagObj, tag);

env->ReleaseStringUTFChars(msgObj, msg);

return res;

}

步骤3 /luni/src/main/native/java_io_File.cpp 文件中加入 jni动态注册中static JNINativeMethod gMethods[] = {

{ "println_native",  "(IILjava/lang/String;Ljava/lang/String;)I", (void*) android_util_Log_println_native },

NATIVE_METHOD(File, listImpl, "(Ljava/lang/String;)[Ljava/lang/String;"),

NATIVE_METHOD(File, readlink, "(Ljava/lang/String;)Ljava/lang/String;"),

NATIVE_METHOD(File, realpath, "(Ljava/lang/String;)Ljava/lang/String;"),

NATIVE_METHOD(File, setLastModifiedImpl, "(Ljava/lang/String;J)Z"),

};

void register_java_io_File(JNIEnv* env) {

jniRegisterNativeMethods(env, "java/io/File", gMethods, NELEM(gMethods));

}

最后一步,编译,可以进入到 libcore 这个目录下使用 mm命令编译,前提是你已经完成的编译过一边android源码,如果对此还不熟悉可以参考网络或者看看我以前写的博文。

编译生成两个文件,一个是 core.jar,一个是 libjavacore.so,

具体位置如下out/target/product/maguro/system/lib/libjavacore.so

out/target/product/maguro/system/framework/core.jar

ok 这个时候将自己的手机以recovery模式启动,将这两个文件在 /system/lib 和 system/framework/下替换掉即可

然后再开机,发现系统里面的apk凡是用到java File类的地方都出现了插入的log

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值