Android应用开发207Package和签名•APK文件介绍•aapt•为什么要签名•签名的注意事项•Android数字证书的有效期•使用Eclipse工具签名•keytool•jarsigner3APK:在Android平台下,程序文件的后缀名为“
APK”,APK是AndroidPackage的缩写,意思是Android安装包,是类似WM系统“
CAB”和Symbian系统“
sis”的文件格式
Apk文件实际是一个zip压缩包,可以通过解压缩工具解开
以下是我们用zip解开helloworld
apk文件后看到的内容,可以看到其结构跟工程结构有些类似:APK文件介绍1
Manifest文件AndroidManifest
xml是每个应用都必须定义和包含的,它描述了应用的名字、版本、权限、引用的库文件等等信息,如要把Apk上传到GoogleMarket上,也要对这个xml做一些配置
META-INF目录META-INF目录下存放的是签名信息,用来保证Apk包的完整性和系统的安全
在eclipse编译生成一个API包时,会对所有要打包的文件做一个校验计算,并把计算结果放在META-INF目录下
而在Android平台上安装Apk包时,应用管理器会按照同样的算法对包里的文件做校验,如果校验结果与META-INF下的内容不一致,系统就不会安装这个Apk
这就保证了Apk包里的文件不能被随意替换
比如拿到一个Apk包后,如果想要替换里面的一幅图片,一段代码,或一段版权信息,想直接解压缩、替换再重新打包,基本是不可能的
如此一来就给病毒感染和恶意修改增加了难度,有助于保护系统的安全
APK文件介绍3
classes
dex文件classes
dex是java源码编译后生成的java字节码文件
但由于Android使用的dalvik虚拟机与标准的java虚拟机是不兼容的,d