問題情景: 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工程裏面的中文文件名改成英文,重新編譯打包,解決!
總結:以後項目裏面文件名絕對不能出現中文字符!太坑了。。。