近来有一个需求,是需要在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 < 0 || 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.soout/target/product/maguro/system/framework/core.jar


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

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

更多相关文章

  1. 一款常用的 Squid 日志分析工具
  2. 分支和循环(二)(零基础学习C语言)
  3. GitHub 标星 8K+!一款开源替代 ls 的工具你值得拥有!
  4. RHEL 6 下 DHCP+TFTP+FTP+PXE+Kickstart 实现无人值守安装
  5. Linux 环境下实战 Rsync 备份工具及配置 rsync+inotify 实时同步
  6. android中引用项目工程中的sqlite文件
  7. Android(安卓)armeabi的so库兼容问题
  8. 关于从Eclipse导入项目到android studio中R文件丢失,会自动导impo
  9. Android中从源码分析关于AsyncTask的使用

随机推荐

  1. 使用Android中的Parcelable序列化对象
  2. Java乔晓松-android中上传图片到服务器To
  3. Android(安卓)apk反编译
  4. Android开发(二十九)——layout_weight的含
  5. android TabHost(选项卡)的使用方法
  6. ZWebView使用简单介绍-Android
  7. 搭建Android(安卓)x86_64及arm64-v8a操作
  8. Android之创建程序快捷方式
  9. Android(安卓)调用系统摄像头
  10. Android(安卓)之 adapter.notifyDataSetC