问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何发布android 应用程序,app增加签名证书

发布网友 发布时间:2022-04-24 07:58

我来回答

1个回答

热心网友 时间:2022-05-01 13:27

  Android系统要求,所有的程序经过数字签名后才能安装。Android系统使用这个证书来识别应用程序的作者,并且建立程序间的信任关系。证书不是用于用户控制哪些程序可以安装。证书不需要授权中心来签名:Android应用程序上使用自己签名的证书是完全允许且普遍的。
  理解Android应用程序签名有以下几个重要点:
  ·所有的应用程序都必须签名。系统不会安装任何一个不签名的程序。
  ·你可以使用自己的证书来签名。不需要任何授权中心。
  ·当你要为最终用户发布你的应用程序的时候,你必须签入一个合适的密钥。你不可以发布程序的时候还使用SDK工具签入的DebugKey。
  ·系统只在安装应用程序的时候检测证书的有效期。如果应用程序在安装之后证书失效了,那么,应用程序还是可以正常工作。
  ·你可以使用标准工具——Keytool和Jarsigner——生成Key并签名apk文件。
  ·一旦你为应用程序签名了,一定要使用zipalign工具来优化最终的APK包。
  Android系统不会安装和运行没有正确签名的应用程序。这条规则适用于任何运行Android系统的地方,不管是真机还是模拟器。正是由于这个原因,你必须在模拟器或真机上运行/调试程序之前对程序进行签名。
  当你调试应用程序时,AndroidSDK工具替你对应用程序进行了签名。Eclipse的ADT插件和Ant编译工具都提供了两种签名模式——Debug模式和Release模式。
  ·当开发和测试时,你可以使用Debug模式。在Debug模式下,编译工具使用内嵌在JDK中的Keytool工具来创建一个keystore和一个key(包含公认的名字和密码)。在每次编译的时候,使用这个DebugKey来为apk文件签名。由于密码是公认的,在每次编译的时候,也不需要提示你输入keystore和key密码。
  ·当你的程序准备发布时,你必须在Release模式下,使用密钥来为apk文件签名。有以下两种方式可以做到:
  1.命令行中使用Keytool和Jarsigner。在这个方法中,首先需要编译出一个未签名的apk。然后使用Jarsigner(或相似的工具),用你的密钥为apk手动签名。如果你没有合适的密钥,你可以运行Keytool来手动生成自己的keystore/key。
  2.使用ADT导出向导。如果你使用Eclipse/ADT插件进行开发,你可以使用导出向导来编译程序,生成密钥(如果需要),并为apk签名,所有这些操作都在导出向导中。一旦你的程序签名了,别忘了运行zipalign来为apk进行额外的优化。
  签名策略
  应用程序签名的某些方面可能会影响应用程序的开发,特别是你打算一起发布多个应用程序的时候。一般来说,推荐的策略是在整个应用程序寿命内,所有的程序签上相同的证书。
  以下有几个应该这么做的原因:
  ·应用程序升级——当你对应用程序进行升级时,如果你想用户平稳的升级,那么,你就需要签上相同的证书。当系统安装一个升级应用程序时,如果新版本的证书与老版本的证书有匹配的话,那么,系统才会允许进行升级。如果你没有为版本签上合适的证书,当你安装时,你需要给应用程序指定一个新的包名——在这种情况下,用户安装的新版本,被当作是一个全新的应用程序。
  ·应用程序模块化——如果应用程序请求的话,Android系统允许签有相同证书的应用程序运行在相同的进程里,这样,系统就会把它们看作是一个单一的应用程序。用这种方法配置应用程序,用户可以选择更新每个独立的模块。
  ·代码/数据权限共享——Android系统提供了基于签名的权限检查,因此,如果应用程序间签有特定的证书,那么,它们之间可以共享功能。通过多个程序签有相同的证书并且使用基于签名的权限检查,你的程序可以以一种安全的方式共享代码和数据。还有一个决定签名策略的重要因素是:如何设定key的有效期。
  ·如果你计划支持单个应用程序的升级,你需要确保你的key拥有一个超过期望的应用程序生命周期的有效期。推荐使用25年或更多的有效期。当你的key过期了,用户也就不能平稳的更新到新版本了。
  ·如果你想给多个无关的应用程序签上相同的key,那么,你必须确保key的有效期超过所有应用程序所有版本的生命周期,包括将来有可能添加到这一阵营的程序。
  ·如果你想在AndroidMarket上发布你的程序,key的有效期必须在2033.10.22以后。Market服务器强制这一要求,目前是保证用户可以平稳的更新他们的程序。
  当你设计应用程序时,一定要把这些点记在脑子里,并且使用一个合适的证书来为应用程序签名。
  签名的基本设定
  在你开始之前,你必须保证Keytool对SDK编译工具来说是可利用的。多数情况下,你可以通过设置JAVA_HOME环境变量来告诉SDK编译工具如何找到Keytool。另外,你还可以添加JDK中Keytool的路径到PATH的变量里。
  如果你在Linux上开发,并且使用GNU编译器来编译Java,那么,请确保系统是使用JDK中的Keytool,而不是gcj。如果Keytool已经在你的PATH中,它有可能是对/usr/bin/keytool的符号链接。在这种情况下,检查符号链接的目标,确保它是指向JDK中的Keytool。如果你打算对公众释放你的应用程序,你还需要Jarsigner工具。Jarsigner和Keytool都包含在JDK中。
  Debug模式下签名
  Android编译工具提供了Debug签名模式,使得开发和调试应用程序更加容易,而且还满足Android系统的签名要求。当使用Debug模式编译你的app时,SDK工具会调用Keytool工具自动创建一个Debug的keystore和key。然后,这个Debugkey会自动用于apk的签名,这样,你不需要使用你自己的key来为应用程序包签名。
  SDK工具使用预先定义好的名字/密码来创建Debugkeystore/key:
  ·Keystore名字:“debug.keysotre”
  ·Keystore密码:“android”
  ·Key别名:“androiddebugkey”
  ·Key密码:“android”
  ·CN:“CN=AndroidDebug,O=Android,C=US”
  如果需要的话,你可以改变Debugkeystore/key的位置和名字,或者提供一个自定义的Debugkeysotre/key。然而,任何自定义的Debugkeystore/key必须使用和默认Debugkey(上面描述的)相同的名字和密码。(在Eclipse/ADT中,操作Windows>Preferences>Android>Build实现。)
  注意:你不能将签有Debug证书的应用程序发布给公众。
  Eclipse用户
  如果你在Eclipse/ADT下开发(并且已经按照上面描述的“签名的基本设定”配置了Keytool),Debug模式下签名默认是开启的。当你运行或是调试应用程序时,ADT会使用Debug证书进行签名,并运行zipalign,然后安装到选择的模拟器或是连接上的设备。整个过程不需要你参与,前提是ADT能访问Keytool。
  Ant用户
  如果你使用Ant来编译你的apk文件,需要在ant命令中添加debug选项来开启Debug签名模式(假设你正在使用由android工具生成build.xml文件)。当你运行antdebug来编译你的程序时,编译脚本会生成一个keystore/key,并为apk进行签名。然后脚本会使用zipalign工具对apk进行对齐处理。整个过程不需要你参与。阅读“其它IDE下开发:Debug模式编译”来了解更多的信息。
  Debug证书过期
  Debug模式下签名用的证书(默认是Eclipse/ADT和Ant编译)自从它创建之日起,1年后就会失效。
  当证书失效时,你会得到一个编译错误,在Ant编译上,
  错误如下:
  debug:
  [echo]Packagingbin/samples-debug.apk,andsigningitwithadebugkey...
  [exec]DebugCertificateexpiredon8/4/083:43PM
  在Eclipse/ADT中,Android控制台上你将会看到一个相似的错误。
  为了解决这个问题,只需要删掉debug.keystore文件即可。AVD默认存储的位置在:~/.android/avd(OSX和Linux),C:DocumentsandSettings\.android(WindowsXP),C:Users\.android(WindowsVista)。
  当下一次编译的时候,编译工具会重新生成一个新的keystore和Debugkey。
  Release模式下签名
  当你的程序准备好释放给其它用户时,你必须:
  1.获取一个合适的密钥
  2.在Release模式下编译程序
  3.使用密钥签名程序
  4.对齐APK包
  如果你是使用Eclipse/ADT插件开发,你可以使用导出向导来完成编译、签名和对齐等操作。在整个过程中,导出向导甚至还可以生成一个新的keystore和密钥。因此,如果你使用Eclipse,你可以直接跳到“使用EclipseADT编译和签名”。
  获取一个合适的密钥为了进行程序的签名,首先,你必须有一个合适的密钥。密钥指:
  ·个人持有。
  ·代表个人、公司或组织实体的身份。
  ·拥有一个有效期。有效期推荐超过25年。
  如果你在AndroidMarket上发布你的程序,需要注意一点的是:程序的有效期需要在2033.10.22之后。你不能上传一个应用程序,而它的key的有效期是在这个日期之前。
  ·不是由AndroidSDK工具生成的Debugkey。
  如果你没有一个合适的key,你一定要使用Keytool来生成一个。如“基本设定”中描述的,确保Keytool可用。
  为了用Keytool生成一个key,使用keytool命令并传入一些可选参数,如下表所示。
  警告:确保密钥的安全。一定要阅读“安全储存你的密钥”中讨论如何确保你的密钥的安全以及这对你和用户为何如此重要。尤其是,当你生成你的密钥时,一定要为keystore和key使用强密码。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
福建南安都有哪些市场 端午节去南安旅行的线路有哪些值得分享? 南安有哪些特色商业街 把一个棱长是10厘米的正方体铁块熔铸成一个底面积是20厘米的圆锥形铁块... 把一块棱长10厘米的正方体铁块熔铸成一个底面直径是20厘米的圆柱形零件... 0x0438ef0指令引用的0x0438ef0内存.该内存不能为“read”的错误提示... SONY 索尼 DSC-RX100M5A 1英寸数码相机 黑色(8.8-25.7mm、F1.8) Vl... SONY 索尼 DSC-RX100M5A 1英寸数码相机 黑色(24-70mm、F1.8-F2.8)-购... 索尼RX100 M5A数码相机 索尼RX100 M5A数码相机:小巧便携,成像卓越 请问一下手机签名证书是什么?有什么用的。 工商银行app登不上,显示签名信息验证失败是怎么回事? 签名app需要刷脸吗 慈溪市是哪个地方? 浙江慈溪有什么好玩的地方吗 宁波和慈溪有什么区别,是不是一个地方的 慈溪是市吗 杭州市慈溪市属于哪个市 关于慈溪的历史介绍 慈溪市属于哪个市 慈溪在浙江哪里 慈溪的民风民俗是什么啊?? 慈溪属于浙江省的哪个市 慈溪三大文化特点 慈溪属于哪个省,哪个市,哪个区 慈溪有几个镇 慈溪在哪里 慈溪的由来 宝宝 淹脖子淹大腿怎么办 宝宝冬天淹脖子怎么办 如何对android的apk签名进行验证 苹果手机下载app签名验证失败怎么办? 签名状态校验不通过的APP安装不了吗 cad中合并命令怎么用 cad合并命令怎么用 CAD炸开是X,那炸开后想合并是什么键 autocad2007的合并命令怎么用? cad中如何合并图纸 武汉市的公共自行车怎么租? 武汉哪里能租到自行车 武汉哪里有双人或者三人骑的那种自行车租啊? cad 合并命令? 我在武汉旅游,明天想骑自行车去武汉大学游览,哪里可以租到自行车 CAD中的合并命令join为啥不能合并多段线??他和Pe命令有什么区别呢?? 武汉东湖景区 有没有可以租的自行车 被套正面的花纹和床单一样吗 武汉城市自行车又几种方式租车 什么样是被套了~被套了怎么办? 武汉东湖哪有租双人自行车的?具体地点在哪?租金多少? 武汉大学内有租自行车的地方吗?在哪里?