Linux源码环境下编译apk实践

29 篇文章 0 订阅
14 篇文章 0 订阅

模拟点击的ap实现中,需要在源码环境下对ap进行编译,

android:sharedUserId="android.uid.system

让ap具有INJEST_EVENT权限。


之前在Linux源码中进行过编译测试,但是编译出来的apk打开就出错。

这次继续研究,还是出错。

01-01 12:01:22.285: E/AndroidRuntime(4807): FATALEXCEPTION: main

01-01 12:01:22.285: E/AndroidRuntime(4807):Process: com.example.test2, PID: 4807

01-01 12:01:22.285: E/AndroidRuntime(4807):java.lang.RuntimeException: Unable to instantiate activityComponentInfo{com.example.test2/com.example.test2.MainActivity}:java.lang.ClassNotFoundException: Didn't find class "com.example.test2.MainActivity"on path: DexPathList[[zip file"/system/app/Test2/Test2.apk"],nativeLibraryDirectories=[/system/app/Test2/lib/arm,/vendor/lib, /system/lib]]

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.ActivityThread.performLaunchActivity(ActivityThread.java:2493)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2691)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.ActivityThread.-wrap11(ActivityThread.java)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.ActivityThread$H.handleMessage(ActivityThread.java:1491)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.os.Handler.dispatchMessage(Handler.java:111)

01-01 12:01:22.285: E/AndroidRuntime(4807):       at android.os.Looper.loop(Looper.java:207)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.ActivityThread.main(ActivityThread.java:5779)

01-01 12:01:22.285: E/AndroidRuntime(4807):       at java.lang.reflect.Method.invoke(NativeMethod)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atcom.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:849)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atcom.android.internal.os.ZygoteInit.main(ZygoteInit.java:739)

01-01 12:01:22.285: E/AndroidRuntime(4807): Causedby: java.lang.ClassNotFoundException: Didn't find class"com.example.test2.MainActivity" on path: DexPathList[[zip file"/system/app/Test2/Test2.apk"],nativeLibraryDirectories=[/system/app/Test2/lib/arm,/vendor/lib, /system/lib]]

01-01 12:01:22.285: E/AndroidRuntime(4807):       atdalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atjava.lang.ClassLoader.loadClass(ClassLoader.java:511)

01-01 12:01:22.285: E/AndroidRuntime(4807):       at java.lang.ClassLoader.loadClass(ClassLoader.java:469)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.Instrumentation.newActivity(Instrumentation.java:1072)

01-01 12:01:22.285: E/AndroidRuntime(4807):       atandroid.app.ActivityThread.performLaunchActivity(ActivityThread.java:2483)

01-01 12:01:22.285: E/AndroidRuntime(4807):       ... 9 more

01-01 12:01:22.285: E/AndroidRuntime(4807):       Suppressed: java.io.IOException: Nooriginal dex files found for dex location /system/app/Test2/Test2.apk

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexFile.openDexFileNative(Native Method)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexFile.openDexFile(DexFile.java:295)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexFile.<init>(DexFile.java:80)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexFile.<init>(DexFile.java:59)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexPathList.loadDexFile(DexPathList.java:279)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexPathList.makePathElements(DexPathList.java:248)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.DexPathList.<init>(DexPathList.java:120)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.BaseDexClassLoader.<init>(BaseDexClassLoader.java:48)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atdalvik.system.PathClassLoader.<init>(PathClassLoader.java:65)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atandroid.app.ApplicationLoaders.getClassLoader(ApplicationLoaders.java:58)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atandroid.app.LoadedApk.getClassLoader(LoadedApk.java:385)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atandroid.app.LoadedApk.makeApplication(LoadedApk.java:580)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atandroid.app.ActivityThread.handleBindApplication(ActivityThread.java:4983)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atandroid.app.ActivityThread.-wrap1(ActivityThread.java)

01-01 12:01:22.285: E/AndroidRuntime(4807):              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1552)

01-01 12:01:22.285: E/AndroidRuntime(4807):              ... 6 more

01-01 12:01:22.285: E/AndroidRuntime(4807):       Suppressed:java.lang.ClassNotFoundException: com.example.test2.MainActivity

01-01 12:01:22.285: E/AndroidRuntime(4807):              atjava.lang.Class.classForName(Native Method)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atjava.lang.BootClassLoader.findClass(ClassLoader.java:781)

01-01 12:01:22.285: E/AndroidRuntime(4807):              at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)

01-01 12:01:22.285: E/AndroidRuntime(4807):              atjava.lang.ClassLoader.loadClass(ClassLoader.java:504)

01-01 12:01:22.285: E/AndroidRuntime(4807):              ... 12 more

01-01 12:01:22.285: E/AndroidRuntime(4807):       Caused by: java.lang.NoClassDefFoundError:Class not found using the boot class loader; no stack trace available

01-01 12:01:25.986: E/AndroidRuntime(4977): FATALEXCEPTION: main

01-01 12:01:25.986: E/AndroidRuntime(4977):Process: com.example.test2, PID: 4977

01-01 12:01:25.986: E/AndroidRuntime(4977):java.lang.RuntimeException: Unable to instantiate activityComponentInfo{com.example.test2/com.example.test2.MainActivity}:java.lang.ClassNotFoundException: Didn't find class "com.example.test2.MainActivity"on path: DexPathList[[zip file"/system/app/Test2/Test2.apk"],nativeLibraryDirectories=[/system/app/Test2/lib/arm,/vendor/lib, /system/lib]]


搜索 Linux源码编译apk,反复试验,终于解决,编译的apk也具有了系统权限,可以实现跨进程的屏幕点击

Android.mk

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

 

LOCAL_MODULE_TAGS := optional

 

LOCAL_SRC_FILES := $(call all-subdir-java-files)

LOCAL_STATIC_JAVA_LIBRARIES += android-support-v4

 

LOCAL_DEX_PREOPT := false

LOCAL_MULTILIB := 32

LOCAL_PACKAGE_NAME := Test2

LOCAL_CERTIFICATE := platform

#LOCAL_CERTIFICATE := share

 

LOCAL_OVERRIDES_PACKAGES := Home

include $(BUILD_PACKAGE)



1 . 把apk拷到apktool根目录下,执行:./apktool d xxx.apk,会生成xxx目录,里面有res目录(各种资源文件),smali目录(类似src目录,里面文件的语法不一样)及AndroidManifest.xml。 [*.apk->*.jar: sh ./dex2jar/dex2jar.sh xxx.apk,生成xxx_dex2jar.jar通过jd-linux源码] 2 . 什么apk汉化啊,就到res/values里string.xml里修改字符串,或者拷贝一份values目录改为values-zh-rCN,再去里面修改string.xml里英文字符串改为中文,所谓的汉化就是这么简单。另外,有些图片里不是中文的得去改图片,那得用Photoshop了,图片也不能乱改,格式,图片大小(尺寸)得原来的。 3 . 修改smali文件,这个有些难度。比如有些apk安装了后要积分什么的,比如大于100才可以用的,其实这个值是用SharedPreference存放的,也就是存在xml里,,位置:/data/data/[包名]/shared_prefs的某个xml里,文件不多肯定是可以找到的。另外一种方法就是修改.smali文件也可以达到这目的,软件实现肯定是读取积分那个值给它修改一下就可以了,例如 const/16 v0 100 (其实就是 v0 = 100)这个语法有点像汇编,觉得还是比汇编简单,v0 v1 ...是寄存器,之前会跟变量关联的。具体的还是自己看看smali语法。 4 . 打包生成apk,执行:./apktool b xxx,会在xxx里面生成,一个dist目录,里面就是xxx.apk,但不能安装滴,提示(Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES]),没有给这个apk签名, 5 . 签名,执行:sh ./dex2jar/d2j-apk-sign.sh ./xxx/dist/xxx.apk 就是给刚才那个apk签名,生成的文件还是xxx.apkapktool根目录下。这样就大功告成啦。 [请看:http://blog.csdn.net/zhouyuanjing/article/details/7446988]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值