前言:首先Android系统区分众多APP是以APP的包名为依据的,一个手机不能安装两个包名相同的app,那么问题来了,包名毕竟是很容易重复的,要是一不小心QQ的包名和微信的包名一样了,那么后安装微信的时候就会替换掉先安装的QQ,怎么办呢?这就是为什么要签名了。安卓系统不会安装没有签名的app,签名时候的一些属性值可以随意写的。但最好有意义,他可以唯一标识开发者。有了签名机制后, 安装新app的时候是这样的:
if(手机里没有与即将要安装的App的同包名的App){
正常执行安装;
}else{//已经安装过同包名的了
if(两个App的签名一样){//他们是同一个App的不同版本
安装新的&替换掉旧的版本;
}else{//这是两个不同的APP,但是他们的包名重复了,不能安装
提示不能安装同包名的两个不同APP;
}
}
安卓系统是不会安装没有签名的APP的,有的人可能要说了,我调试的时候明明没有签名啊?连个数据线也能安装运行呀?
关于这个,大哥哥你别着急,平时调试状态下编辑器会自动为你签名的。当然了,你也可以自己签名的,并不矛盾哈。
好了,既然签名这么重要(反正我是感觉到他的重要性了)那么我们到底怎么签名呢?
1、首先,签名的时候需要一个keystore文件,然后用他签名就行了。那么怎么去生成怎个文件呢?
2、我们安装的jdk里面就有一个用来签名的程序,他叫:keytool.exe,在jdk的bin目录下。
3、 然而我们不能直接启动它,会闪退的,要在命令行打开它:
在命令行输入keytool获取keytool的帮助文档,然后开始工作:
第一步:输入一下信息要求产生签名文件:
OK,写完之后注意了,问你信息是否正确?有误的话,直接回车重新输入,确认无误的话请输入Y再回车,然后这个签名文件就生成了,他在JDK的bin目录下,签名的时候用上它就行了。
4、有时候我们想要看它的详细信息,输入下面的命令:
keytool -list -v -keystore android.keystore
就可以看见了。