平时在使用eclipse进行android project开发时,因为每一个项目组都有自身的签名,但默认Eclipse ADT调试运行使用的是临时生成的Debug证书,默认为C:\Users\XXX\.android\debug.keystore。 android
每次调试程序必须使用ADT的Export Signed Application Package打带正式签名的包,或者另写从新签名脚本,比较麻烦。 eclipse
后来发现ADT容许自定义调试用证书,在Window->Preferences->Android->Build->Custom debug keystore这里 工具
试了一下选择正式证书后提示:”Keystore was tampered with, or password was incorrect” ui
其实这个界面并无提供输入Keystore密码,选择别名之类的地方,因此就感到很是奇怪了,查了一下官方文档发现,即便是自定义的调试证书,也须要保证和默认证书同样的密码,别名alias和别名密码。 命令行
文档中提到的默认证书信息以下: debug
Keystore name: “debug.keystore” 调试
Keystore password: “android”
Key alias: “androiddebugkey”
Key password: “android”
CN: “CN=Android Debug,O=Android,C=US” ip
遵循这个规则就能够用自定义调试证书了。不过仔细想一想感受这功能这样非常鸡肋,但愿之后版本的ADT会改进吧。 开发
那么,咱们就能够按照android默认证书规范,更改项目的签名文件的密码,别名和别名密码。而后将 "Custom debug keystore" 设置为修改事后的签名文件。 文档
具体操做步骤以下:
1. 首先固然是先复制一份正式证书出来做为要修改成的临时调试证书。
2. 修改keystore密码的命令(keytool为JDK带的命令行工具):
keytool -storepasswd -keystore my.keystore
其中,my.keystore是复制出来的证书文件,执行后会提示输入证书的当前密码,和新密码以及重复新密码确认。这一步须要将密码改成android。
3. 修改keystore的alias:
keytool -changealias -keystore my.keystore -alias my_name -destalias androiddebugkey
这一步中,my_name是证书中当前的alias,-destalias指定的是要修改成的alias,这里按规矩来,改成androiddebugkey!这个命令会前后提示输入keystore的密码和当前alias的密码。
4. 修改alias的密码:
keytool -keypasswd -keystore my.keystore -alias androiddebugkey
这一步执行后会提示输入keystore密码,alias密码,而后提示输入新的alias密码,一样,按规矩来,改成android!