最近一个项目里需要得到Android已安装程序的签名文件(CERT.RSA)的SHA1值,所以就调研解压APK文件。
private static String getApkPath(String pkgName) { PackageManager pm = mContext.getPackageManager(); ApplicationInfo pi = null; try { pi = pm.getApplicationInfo(pkgName,PackageManager.GET_UNINSTALLED_PACKAGES); if(pi != null) return pi.sourceDir; else return null; } catch (NameNotFoundException e) { e.printStackTrace(); return null; } }
public static void UnZip(String unzipfile){ try { File zipFile = new File(unzipfile); //解压缩的文件路径(为了获取路径) if(!zipFile.exists()) { Log.i(TAG,"FILE !EXIST"); return ; } ZipInputStream zin = new ZipInputStream(new FileInputStream(zipFile)); ZipEntry entry; while ( (entry = zin.getNextEntry()) != null){ if (!entry.isDirectory()) { //匹配文件,跳过文件夹 String filePath = entry.getName(); Pattern p = Pattern.compile(".*(RSA|DSA|rsa)$"); //匹配RSA后缀的文件 Matcher m = p.matcher(filePath); if(m.matches()) { ByteArrayOutputStream baos = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int count; while ((count = zin.read(buffer)) != -1) { baos.write(buffer, 0, count); } try { String sha1 = Sha1.getSha1(baos); Log.i(TAG, "Sha1:"+sha1+""); } catch (Exception e) { e.printStackTrace(); } } } }//while zin.closeEntry(); }//try catch (IOException e) { e.printStackTrace(); } }
主要就是通过ZipInputStream来读取对应文件,然后将该文件写到SD卡上,然后调用sha1方法读取该文件得到sha1值。
ZipInputStream类,比较重要,值得学习一下。
SDK里:
总结:ZipInputStream是InputStream的子类,通过此类可以方便地读取ZIP格式的压缩文件。
通过ZipInputStream类中的getNextEntry()方法可以依次取得每一个ZipEntry,那么将此类与ZipFile结合就可以对压缩的文件夹进行解压缩操作。但是需要注意的是,在mldndir.zip文件中本身是包含压缩的文件夹的,所以在进行解压缩前,应该先根据ZIP文件中的文件夹的名称在硬盘上创建好一个对应的文件夹,然后才能把文件解压缩进去,而且在操作时对于每一个解压缩的文件都必须先创建(File类的createNewFile()方法可以创建新文件)后再将内容输出。