Frida 问题集锦

1. 使用过程中少用this

Activity.onStart.implementation = function() {
            console.log('onStart: ' + this);
            this.onStart();

            //public static void SomeClass.init(final Context var0)
            SomeClass.init(this);
}

上面的代码中,当调用SomeClass.init(this) 方法会导致SomeClass的初始化不成功,因为这里的this并不是Activity的this实例,应该采用下面的方式调用

Activity.onStart.implementation = function() {
            console.log('onStart: ' + this);
            this.onStart();

            //public static void SomeClass.init(final Context var0)
           var activityThis = this
            SomeClass.init(activityThis);
}

2. 通过 Java.registerClass 注册一个类时,如果需要在有参数的构造方法中调用父类有参数的构造方法需要采用下面的方式

 

var MyHandler = Java.registerClass({
        name:'com.test.pq.MyHandler',
        superClass: Handler,
        methods: {
        //public Handler(Looper looper) $init:{ argumentTypes:['android.os.Looper'], implementation: function(looper){ Handler.$init.overload('android.os.Looper').call(this, looper) }}, handleMessage:{ returnType:'void', argumentTypes:['android.os.Message'], implementation:function(msg) { console.log('handleMessage:' + msg.what) if (1000 == msg.what) { //心跳处理 } }} } });

 

上面的代码新注册了一个Handler的子类,构造方法要实现Handle(Looper)。在调用父类的构造方法时call()方法中一定要传this实例,否则MyHandler类实例的looper将为null。

 

上一篇:JVM jclasslib使用


下一篇:Android中UI线程与后台线程交互设计的5种方法