tar -zxvf 文件名.tar.gz
其中,文件名.tar.gz
是你要解压的.tar.gz文件的名称。解压命令选项的含义如下:
-z
:表示使用gzip算法进行解压缩。-x
:表示解压缩操作。-v
:可选项,表示在解压过程中显示详细信息。-f
:后面跟着要解压的文件名。请确保在执行解压命令之前已经安装了tar工具,并且指定的文件名正确。解压后的文件将会被提取到当前目录或指定的输出目录中。
当你解压一个APK文件时,其中的CERT.RSA是APK文件的签名证书文件。APK文件经过签名后,可以验证APK的完整性和来源的真实性。
CERT.RSA文件包含了用于验证APK签名的公钥证书和数字签名信息。它通常位于META-INF目录下。
如果你希望查看APK的签名证书信息,你可以执行以下步骤:
请注意,CERT.RSA文件是二进制文件,因此无法直接阅读其内容。如果你想要查看证书信息,可以使用Java Keytool或其他证书工具对CERT.RSA文件进行解析和查看。
备注:android sdk版本不同,安装之后在tools下可能会少dx.bat,apkbuilder.bat文件,通过升级SDK或者单独下载放在对应的目录,也可正常使用; 一、手动编译APK的流程如下:
1.生成资源文件:使用Android SDK提供的aapt.exe生成R.java类文件
2.编译本地库:使用Android SDK提供的aidl.exe把.aidl转成.java文件(如果没有aidl,则跳过这一步)
3.编译java代码:使用JDK提供的javac.exe编译.java类文件生成class文件
4.生成dex文件:使用Android SDK提供的dx.bat命令行脚本生成classes.dex文件
5.打包资源文件:使用Android SDK提供的aapt.exe生成资源包文件(包括res、assets、androidmanifest.xml等)
6.生成apk文件:使用Android SDK提供的apkbuilder.bat生成未签名的apk安装文件
7.对apk文件进行签名:使用jdk的jarsigner.exe对未签名的包进行apk签名
二、详细步骤
1)、准备工作
A、安装好JDK,配置环境变量;
B、将android-sdk-windows\platform-tools和 android-sdk-windows\tools 添加到CLASSPATH 环境变量中;
C、打开CMD命令行界面,将当前目录切换到工程所在目录;
D、准备一个目录,以下例子是以在eclipse中创建的Android test project项目,名称Test;
2)生成资源文件,使用aapt生成R.java类文件,aapt所在路径android-sdk-windows\platform-tools\aapt.exe:
E:\Users\Administrator\workspace\Test>aapt package -f -m -J gen -S res -M AndroidManifest.xml -I E:\android-sdk_r23.0.2-windows\android-sdk-windows\platforms\android-18\android.jar
说明:
3)javac.exe编译.java类文件生成class文件,javac所在路径C:\Program Files\Java\jdk1.6.0_43\bin\javac.exe
E:\Users\Administrator\workspace\Test>javac -encoding utf-8 -target 1.6 -d bin -bootclasspath E:\android-sdk_r23.0.2-windows\android-sdk-windows\platforms\android-18\android.jar gen\android\support\v7\appcompat\test\*.java src\android\support\v7\appcompat\test\*.java
说明:-target:jdk版本;-d:指定生成的class类文件存放的位置;-bootclasspath:覆盖引导类文件的位置;-encoding:后面跟字符编码,避免出现乱码;
4)使用dx.bat命令行脚本生成classes.dex文件,dx.bat所在路径android-sdk-windows\tools\dx.bat
E:\Users\Administrator\workspace\Test>dx.bat --dex --output=E:\Users\Administrator\workspace\Test\bin\classes.dex E:\Users\Administrator\workspace\Test\bin\classes
说明:–output:生成的dex文件存放路径;最后带上class文件所在目录,不需要加包目录
5)使用aapt.exe生成资源包文件,aapt.exe所在路径android-sdk_r23.0.2-windows\android-sdk-windows\platform-tools\aapt.exe
E:\Users\Administrator\workspace\Test>aapt.exe package -f -M AndroidManifest.xml -S res -A assets -I E:\android-sdk_r23.0.2-windows\android-sdk-windows\platforms\android-18\android.jar -F bin\resourcesLater
说明:-S:资源目录;-M:AndroidManifest.xml文件;-I:导入用的jar文件;-F:后面跟生成的资源文件存放位置,生成的资源文件名是自己新建的
6)使用apkbuilder.bat生成未签名的apk安装文件,apkbuilder.bat所在路径android-sdk_r23.0.2-windows\android-sdk-windows\tools\apkbuilder.bat。 (使用该命令时:会提示该工具已过时,Google不推荐使用。而推荐使用的是:com.android.ant.ApkBuilderTask,但apk仍能成功生成)
E:\Users\Administrator\workspace\Test>apkbuilder E:\Users\Administrator\workspace\Test\bin\HelloWorld.apk -u -z E:\Users\Administrator\workspace\Test\bin\resourcesLater -f E:\Users\Administrator\workspace\Test\bin\classes.dex -rf E:\Users\Administrator\workspace\Test\src
THIS TOOL IS DEPRECATED. See --help for more information. 说明:-z:资源打包文件;-f:类打包文件;-rf:源代码目录;
(备注:此步骤没有成功给apk签名) 7)使用jarsigner.exe对未签名的包进行apk签名,jarsigner.exe所在路径C:\Program Files\Java\jdk1.6.0_43\bin\jarsigner.exe
E:\Users\Administrator\workspace\Test>jarsigner -verbose -keystore E:\Users\zhengshu_apk -signedjar E:\Users\Administrator\workspace\Test\bin\HelloWorld.apk E:\Users\Administrator\workspace\Test\bin\HelloWorld.apk.mydeystore
说明:-keystore:keystore文件;-signedjar:签名后的文件;后面还有未签名文件和key的alias
用法:
jarsigner [选项] jar 文件别名
jarsigner -verify [选项] jar 文件