Java 索引缓存目录为';t可写:/data/dalvik缓存
如果需要,请编辑问题 我正在使用安卓UiAutomator UiAutomation运行得很好,但我希望在UiAutomator.jar(内部包含claasses.dex)上使用java反射 所以问题是java反射API使用了一些.jar文件(其中包含Java 索引缓存目录为';t可写:/data/dalvik缓存,java,android,jar,android-uiautomator,Java,Android,Jar,Android Uiautomator,如果需要,请编辑问题 我正在使用安卓UiAutomator UiAutomation运行得很好,但我希望在UiAutomator.jar(内部包含claasses.dex)上使用java反射 所以问题是java反射API使用了一些.jar文件(其中包含xyz.class而不是.dex) 那么如何从UiAutomationTest.jar访问这个.dex文件呢 我正在使用这个工具将.dex转换为.jar(包含.class文件) 链接: 我需要它的程序- 现在我无法将UiAutomator.jar加
xyz.class
而不是.dex
)
那么如何从UiAutomationTest.jar访问这个.dex文件呢
我正在使用这个工具将.dex
转换为.jar(包含.class
文件)
链接:
我需要它的程序-
现在我无法将UiAutomator.jar加载到内存中(为了从jar获取.dex文件,然后再次将其转换为claasses.dex到classes.jar-)
所以这是一个错误
我正在使用的代码剪切。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Here I am placed my UiAutomationTest.jar which produce from UiAutomation ant build tool.
String sourceDir = Environment.getExternalStorageDirectory().toString()+"/UiAutomationTest.jar"; //getApplicationInfo().sourceDir;
try {
DexFile dexFile = new DexFile(sourceDir); // Exception propagate from here.
} catch (IOException e) {
e.printStackTrace();
}
//exploreJar(); // For exploring jar from dex.
}
Logcat消息:
07-31 15:50:18.339: E/dalvikvm(19748): Dex cache directory isn't writable: /data/dalvik-cache
07-31 15:50:18.339: W/System.err(19748): java.io.IOException: unable to open DEX file
07-31 15:50:18.339: W/System.err(19748): at dalvik.system.DexFile.openDexFile(Native Method)
07-31 15:50:18.339: W/System.err(19748): at dalvik.system.DexFile.<init>(DexFile.java:78)
07-31 15:50:18.339: W/System.err(19748): at com.example.dextestproject.MainActivity.onCreate(MainActivity.java:35)
07-31 15:50:18.349: W/System.err(19748): at android.app.Activity.performCreate(Activity.java:5008)
07-31 15:50:18.349: W/System.err(19748): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
07-31 15:50:18.349: W/System.err(19748): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2026)
07-31 15:50:18.349: W/System.err(19748): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2087)
07-31 15:50:18.349: W/System.err(19748): at android.app.ActivityThread.access$600(ActivityThread.java:133)
07-31 15:50:18.349: W/System.err(19748): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1198)
07-31 15:50:18.349: W/System.err(19748): at android.os.Handler.dispatchMessage(Handler.java:99)
07-31 15:50:18.349: W/System.err(19748): at android.os.Looper.loop(Looper.java:137)
07-31 15:50:18.349: W/System.err(19748): at android.app.ActivityThread.main(ActivityThread.java:4803)
07-31 15:50:18.349: W/System.err(19748): at java.lang.reflect.Method.invokeNative(Native Method)
07-31 15:50:18.349: W/System.err(19748): at java.lang.reflect.Method.invoke(Method.java:511)
07-31 15:50:18.349: W/System.err(19748): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
07-31 15:50:18.349: W/System.err(19748): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
07-31 15:50:18.359: W/System.err(19748): at dalvik.system.NativeStart.main(Native Method)
07-31 15:50:18.339:E/dalvikvm(19748):索引缓存目录不可写:/data/dalvik缓存
07-31 15:50:18.339:W/System.err(19748):java.io.IOException:无法打开DEX文件
07-31 15:50:18.339:W/System.err(19748):位于dalvik.System.DexFile.openDexFile(本机方法)
07-31 15:50:18.339:W/System.err(19748):位于dalvik.System.DexFile.(DexFile.java:78)
07-31 15:50:18.339:W/System.err(19748):位于com.example.dextestproject.MainActivity.onCreate(MainActivity.java:35)
07-31 15:50:18.349:W/System.err(19748):位于android.app.Activity.performCreate(Activity.java:5008)
07-31 15:50:18.349:W/System.err(19748):位于android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
07-31 15:50:18.349:W/System.err(19748):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2026)
07-31 15:50:18.349:W/System.err(19748):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2087)
07-31 15:50:18.349:W/System.err(19748):在android.app.ActivityThread.access$600(ActivityThread.java:133)
07-31 15:50:18.349:W/System.err(19748):位于android.app.ActivityThread$H.handleMessage(ActivityThread.java:1198)
07-31 15:50:18.349:W/System.err(19748):位于android.os.Handler.dispatchMessage(Handler.java:99)
07-31 15:50:18.349:W/System.err(19748):位于android.os.Looper.loop(Looper.java:137)
07-31 15:50:18.349:W/System.err(19748):位于android.app.ActivityThread.main(ActivityThread.java:4803)
07-31 15:50:18.349:W/System.err(19748):位于java.lang.reflect.Method.invokenactive(本机方法)
07-31 15:50:18.349:W/System.err(19748):位于java.lang.reflect.Method.invoke(Method.java:511)
07-31 15:50:18.349:W/System.err(19748):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
07-31 15:50:18.349:W/System.err(19748):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
07-31 15:50:18.359:W/System.err(19748):在dalvik.System.NativeStart.main(本机方法)
正如我从这里学到的
你应使用:
File f = new File(Environment.getExternalStorageDirectory()+"/classes.zip");
File tmp = new File(Environment.getExternalStorageDirectory()+"/classes.odex");
DexFile dexfile = DexFile.loadDex(f.getAbsolutePath(), tmp.getAbsolutePath(), 0);
而不是:
DexFile dexfile = new DexFile(f);
正如我从这里学到的
你应使用:
File f = new File(Environment.getExternalStorageDirectory()+"/classes.zip");
File tmp = new File(Environment.getExternalStorageDirectory()+"/classes.odex");
DexFile dexfile = DexFile.loadDex(f.getAbsolutePath(), tmp.getAbsolutePath(), 0);
而不是:
DexFile dexfile = new DexFile(f);
注意:调用
DexFile.loadDex
一次后,outputPathName
的路径和文件名完全相同,但扩展名是odex
而不是zip
newdexfile(“……zip”)
也将神奇地开始工作。注意:调用DexFile.loadDex
一次后,outputPathName
的路径和文件名完全相同,但扩展名是odex
而不是zip
newdexfile(“……zip”)
也将神奇地开始工作。