逆向某音时,调用libCms.so时遇到的问题
当我拷贝出某音(当前11.2)的libCms.so,然后试着自己调用里面的native方法,比如meta方法,它的整个类的方法签名如下:
package com.ss.sys.ces;
import android.content.Context;
public class a {
static {
try {
System.loadLibrary("cms");
} catch (UnsatisfiedLinkError unused) {
}
}
public static byte[] sMetaData;
static {
}
private static final void Bill() {
}
public final strictfp void Francies() {
}
public static final void Louis() {
}
public static final void Zeoy() {
}
public static native byte[] decode(int arg0, byte[] arg1);
public static native byte[] encode(byte[] arg0);
public static native byte[] leviathan(int arg0, int arg1, byte[] arg2);
public static native Object meta(int arg0, Context arg1, Object arg2) ;
public static Object njss(int arg3, Object arg4) {
return null;
}
}
特别注意:调用第三方的so,包结构和方法的签名千万不能错,也不能随意的删除任何方法,但是可以添加自己的方法,native方法和非native都行,对于原非native的方法,其方法体代码可以修改,如上面的njss方法直接修改成return null了。另外so只需拷贝armeabi-v7a的so即可。
当我随手按照新建一个简单的项目试图调用so里的meta方法时,却发现直接报错
java.lang.UnsatisfiedLinkError: No implementation found for java.lang.Object com.ss.sys.ces.a.meta(int, android.content.Context, java.lang.Object) (tried Java_com_ss_sys_ces_a_meta and Java_com_ss_sys_ces_a_meta__ILandroid_content_Context_2Ljava_lang_Object_2)
at com.ss.sys.ces.a.meta(Native Method)
难道是像userinfo这种so在代码里做了很多前置校验么,有点不太可能,偶然在一个低版本的android studio 测试上找到了问题,只要gradle插件版本低于3.5即可,而gradle版本则没有限制
在project build.gradle ,修改插件版本为
classpath 'com.android.tools.build:gradle:3.4.1'
这其中的原因也不知道为什么,除非去查看编译后的代码,有点匪夷所思,gradle 打包居然会影响程序的结果。