问题情景: Android studio library工程打包aar,aar包导入主项目app,编译,gradle报错:MALFORMED ;重新try,clean rebuild 都无效。。。。
然后点击右上show 异常日志,打开idea.log ,发现是解压aar包异常,IllegalArgumentException此异常表明向方法传递了一个不合法或不正确的参数,
java.lang.IllegalArgumentException: MALFORMED
at java.util.zip.ZipCoder.toString(ZipCoder.java:58)
at java.util.zip.ZipFile.getZipEntry(ZipFile.java:566)
at java.util.zip.ZipFile.access$900(ZipFile.java:60)
at java.util.zip.ZipFile$ZipEntryIterator.next(ZipFile.java:524)
at java.util.zip.ZipFile$ZipEntryIterator.nextElement(ZipFile.java:499)
at java.util.zip.ZipFile$ZipEntryIterator.nextElement(ZipFile.java:480)
at com.intellij.openapi.vfs.impl.ZipHandler.createEntriesMap(ZipHandler.java:91)
at com.intellij.openapi.vfs.impl.ArchiveHandler.getEntriesMap(ArchiveHandler.java:124)
at com.intellij.openapi.vfs.impl.ArchiveHandler.getEntryInfo(ArchiveHandler.java:108)
at com.intellij.openapi.vfs.impl.ArchiveHandler.list(ArchiveHandler.java:90)
at com.intellij.openapi.vfs.newvfs.ArchiveFileSystem.list(ArchiveFileSystem.java:153)
at com.intellij.openapi.vfs.newvfs.persistent.PersistentFSImpl.persistAllChildren(PersistentFSImpl.java:151)
at com.intellij.openapi.vfs.newvfs.persistent.PersistentFSImpl.listAll(PersistentFSImpl.java:195)
at com.intellij.openapi.vfs.newvfs.impl.VirtualDirectoryImpl.getChildren(VirtualDirectoryImpl.java:305)
at com.android.tools.idea.apk.viewer.ApkParser.createTreeNode(ApkParser.java:136)
at com.android.tools.idea.apk.viewer.ApkParser.lambda$constructTreeStructure$0(ApkParser.java:67)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
找到原因:中文文件名惹的祸 (assets里面有个中文名文件,“时尚中黑简体.ttf”)
问题处理:把library工程里面的中文文件名改成英文,重新编译打包,解决!
总结:以后项目里面文件名绝对不能出现中文字符!太坑了。。。