Android signed APK程序正式签名方法详解

本网站用的阿里云ECS,推荐大家用。自己搞个学习研究也不错

<

div id=”content”>Android程序的签名用户在开发时通过ADB接口上传的程序会自动被签有Debug权限的程序,但是在上传程序到Android Market上或者到设备上时则需要正式签名。Android signed制作方法主要使用Keytool和Jarsigner两个工具制作,具体方法如下:

详细的签名步骤:
第一步 生成个人签名密钥库基础数据
用keytool生成证书:
-alias myandroid 证书别名,-keyalg RSA  指的是采用的RSA算法,-keystore myandroid.keystore是指生成的证书存储的位置。回车后会提示你输入keystore password,这可以自己定,然后是一些个人信息及组织信息,可以轻松搞定。
-validity 缺省时间是90 天,建议设置一个较长的天数  

具体实例如下:

D:\Android\00STUDY\myandorid>keytool -genkey -alias myandroid -keyalg R
SA -validity 20000 -keystore myandroid.keystore
输入keystore密码:  *************
您的名字与姓氏是什么?
  [Unknown]:  monner
您的组织单位名称是什么?
  [Unknown]:  monner
您的组织名称是什么?
  [Unknown]:  monner
您所在的城市或区域名称是什么?
  [Unknown]:  gz
您所在的州或省份名称是什么?
  [Unknown]:  gd
该单位的两字母国家代码是什么
  [Unknown]:  cn
CN=monner, OU=monner, O=monner, L=gz, ST=gd, C=cn 正确吗?
  [否]:  y

输入的主密码
        (如果和 keystore 密码相同,按回车):

 
第二步 apk文件签名命令
方法很简单,执行jarsigner命令行即可,基本命令格式如下:

jarsigner -verbose -keystore your-release-key.keystore your-release.apk your-alias-name

 

具体实例如下:

D:\Android\00STUDY\myandorid\bin>jarsigner -verbose -keystore .\myandroid.keysto
re  myandroid-unsigned.apk    myandroid
输入密钥库的口令短语: *************(程序提示输入的密码和keytool输入的一样即可成功。 )

   正在添加: META-INF/MANIFEST.MF
   正在添加: META-INF/MYANDROI.SF
   正在添加: META-INF/MYANDROI.RSA
  正在签名: res/layout/main.xml
  正在签名: AndroidManifest.xml
  正在签名: resources.arsc
  正在签名: res/drawable-hdpi/icon.png
  正在签名: res/drawable-ldpi/icon.png
  正在签名: res/drawable-mdpi/icon.png
  正在签名: classes.dex

警告: 签名者证书将在六个月内过期。

用户输入的未签名文件会自动变为已签名的apk文件,文件名不变。

 

 

更详细Android程序发布和签名可查看SDK http://code.google.com/android/devel/sign-publish.html  .

========================================

附: keytool参数和jarsigner参数详解
  keytool用法 :
-certreq     [-v] [-protected]
             [-alias ] [-sigalg ]
             [-file ] [-keypass ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-changealias [-v] [-protected] -alias -destalias
             [-keypass ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-delete      [-v] [-protected] -alias
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-exportcert  [-v] [-rfc] [-protected]
             [-alias ] [-file ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-genkeypair  [-v] [-protected]
             [-alias ]
             [-keyalg ] [-keysize ]
             [-sigalg ] [-dname ]
             [-validity ] [-keypass ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-genseckey   [-v] [-protected]
             [-alias ] [-keypass ]
             [-keyalg ] [-keysize ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-help
-importcert  [-v] [-noprompt] [-trustcacerts] [-protected]
             [-alias ]
             [-file ] [-keypass ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-importkeystore [-v]
             [-srckeystore ] [-destkeystore ]
             [-srcstoretype ] [-deststoretype ]
             [-srcstorepass ] [-deststorepass ]
             [-srcprotected] [-destprotected]
             [-srcprovidername ]
             [-destprovidername ]
             [-srcalias [-destalias ]
               [-srckeypass ] [-destkeypass ]]
             [-noprompt]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-keypasswd   [-v] [-alias ]
             [-keypass ] [-new ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-list        [-v | -rfc] [-protected]
             [-alias ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]
-printcert   [-v] [-file ]
-storepasswd [-v] [-new ]
             [-keystore ] [-storepass ]
             [-storetype ] [-providername ]
             [-providerclass [-providerarg ]] …
             [-providerpath ]

jarsigner用法 : [选项] jar 文件别名
       jarsigner -verify [选项] jar 文件
[-keystore ]           密钥库位置
[-storepass ]         用于密钥库完整性的口令
[-storetype ]         密钥库类型
[-keypass ]           专用密钥的口令(如果不同)
[-sigfile ]           .SF/.DSA 文件的名称
[-signedjar ]         已签名的 JAR 文件的名称
[-digestalg ]    摘要算法的名称
[-sigalg ]       签名算法的名称
[-verify]                   验证已签名的 JAR 文件
[-verbose]                  签名/验证时输出详细信息
[-certs]                    输出详细信息和验证时显示证书
[-tsa ]                时间戳机构的位置
[-tsacert ]           时间戳机构的公共密钥证书
[-altsigner ]           替代的签名机制的类名
[-altsignerpath ] 替代的签名机制的位置
[-internalsf]               在签名块内包含 .SF 文件
[-sectionsonly]             不计算整个清单的散列
[-protected]                密钥库已保护验证路径
[-providerName ] ¼/div>

未经允许不得转载:演道网 » Android signed APK程序正式签名方法详解

赞 (0)
分享到:更多 ()

评论 0

评论前必须登录!

登陆 注册