`

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

阅读更多

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

输入<myandroid.keystore>的主密码
        (如果和 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 <sigalg>]
             [-file <csr_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 <keyalg>] [-keysize <密钥大小>]
             [-sigalg <sigalg>] [-dname <dname>]
             [-validity <valDays>] [-keypass <密钥库口令>]
             [-keystore <密钥库>] [-storepass <存储库口令>]
             [-storetype <存储类型>] [-providername <名称>]
             [-providerclass <提供方类名称> [-providerarg <参数>]] ...
             [-providerpath <路径列表>]
-genseckey   [-v] [-protected]
             [-alias <别名>] [-keypass <密钥库口令>]
             [-keyalg <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 <url>]           密钥库位置
[-storepass <口令>]         用于密钥库完整性的口令
[-storetype <类型>]         密钥库类型
[-keypass <口令>]           专用密钥的口令(如果不同)
[-sigfile <文件>]           .SF/.DSA 文件的名称
[-signedjar <文件>]         已签名的 JAR 文件的名称
[-digestalg <算法>]    摘要算法的名称
[-sigalg <算法>]       签名算法的名称
[-verify]                   验证已签名的 JAR 文件
[-verbose]                  签名/验证时输出详细信息
[-certs]                    输出详细信息和验证时显示证书
[-tsa <url>]                时间戳机构的位置
[-tsacert <别名>]           时间戳机构的公共密钥证书
[-altsigner <类>]           替代的签名机制的类名
[-altsignerpath <路径列表>] 替代的签名机制的位置
[-internalsf]               在签名块内包含 .SF 文件
[-sectionsonly]             不计算整个清单的散列
[-protected]                密钥库已保护验证路径
[-providerName <名称>]      提供者名称
[-providerClass <类>        加密服务提供者的名称
[-providerArg <参数>]] ... 主类文件和构造函数参数
声明:JavaEye文章版权属于作者,受法律保护。

分享到:
评论

相关推荐

    android应用APK打包签名方法文档

    ### Android应用APK打包签名方法详解 #### 一、引言 在Android开发过程中,APK的打包与签名是一项至关重要的环节。无论是开发者在本地测试应用,还是将应用提交到Google Play商店,都需要确保APK文件正确地进行了...

    Android apk 空包签名说明

    ### Android APK空包签名详解 #### 一、引言 在Android应用开发过程中,签名是发布应用程序的一个重要环节。正确地进行签名不仅能够确保应用程序的完整性和安全性,还能避免因签名问题导致的应用无法正常更新或...

    android apk 签名

    ### Android APK签名详解 在Android应用开发过程中,为了确保应用程序的安全性和完整性,对APK进行签名是一项必不可少的操作。本文将详细介绍Android APK签名的过程及其涉及的关键工具和技术。 #### 一、生成数字...

    android APK 重新签名

    ### Android APK 重新签名知识点详解 #### 一、概述 在Android开发过程中,有时需要对已有的APK文件进行重新签名。例如,在某些情况下,原始的签名密钥可能丢失或出于安全考虑需更换签名密钥;又或者是在进行二次...

    Android成成.apk应用程序(图解)

    本篇将详细讲解如何创建并理解一个Android `.apk`应用程序的过程,通过图解的方式帮助你更好地理解每个步骤。 1. **编译应用**: 在Android开发环境中,如Android Studio,开发者编写完应用代码后,需要编译项目。...

    APK签名解析示例

    在Android开发中,APK签名是一个至关重要的环节,它确保了应用的安全性和完整性。本文将深入探讨APK签名的概念、过程以及如何通过示例进行签名操作。我们将参考文章《APK签名流程详解》...

    解决在eclipse中将android项目生成apk并且给apk签名的实现方法详解

    标题:“解决在eclipse中将android项目生成apk并且给apk签名的实现方法详解”所涵盖的知识点包括: 一、Android APK签名的意义 在Android平台上,所有应用程序在发布前都需要进行签名,这个过程确保了应用程序的...

    Android程序打包为APK的方法详解

    Android程序打包为APK的方法详解可以分为两步:生成未签名的安装包、生成签名的安装包。其中,生成签名的安装包是Android程序打包为APK的最重要的一步,因为签名的安装包可以确保应用程序的安全和可靠性。 希望本文...

    Android中APK签名工具之jarsigner和apksigner详解

    apksigner是Google官方提供的针对Android apk签名及验证的专用工具, 位于Android SDK/build-tools/SDK版本/apksigner.bat 不管是apk包,还是jar包,本质都是zip格式的压缩包,所以它们的签名过程都差不多(仅限V1签名),...

    android系统签名工具

    java -jar SignApk.jar platform.x509.pem platform.pk8 app_unsigned.apk app_signed.apk 其中SignApk.jar platform.x509.pem platform.pk8都打包在下载的压缩包中,app_unsigned.apk则是编译好等待签名的apk

    Android 程序如何生成签名文件

    ### Android程序如何生成签名文件 在开发Android应用的过程中,对应用程序进行签名是非常重要的一步,它不仅确保了应用的完整性和来源可信度,还为应用更新提供了便利。本篇文章将详细介绍如何为Android应用程序...

    android打包成apk[定义].pdf

    ### Android项目打包成APK文件详解 在进行Android应用开发时,最终的目标是将开发完成的应用程序打包成可以在Android设备上安装与运行的APK文件(Android Package Kit)。本篇文章将详细介绍如何使用Eclipse IDE...

    Android签名工具

    Android签名工具(SignApk)是一个Java应用程序,它使用密钥对APK进行签名,以便可以在Android设备上安装和运行。本文将详细讲解Android签名工具的使用、工作原理以及其在Android开发中的重要性。 ### 1. Android...

    Android Studio打包APK软件步骤

    ### Android Studio 打包 APK 软件步骤详解 #### 前言 在移动应用开发领域,Android Studio 是一款非常流行的集成开发环境(IDE),主要用于构建 Android 应用程序。其中,打包 APK(Android Package Kit)是开发...

    Android studio打包方法.docx

    Android Studio 打包方法详解 Android Studio 是一款功能强大且流行的集成开发环境(IDE),广泛应用于 Android 应用程序的开发和调试。然而,在将应用程序发布到 Google Play 商店或其他应用商店之前,需要对其...

    android签名完整版

    ### Android APK签名详解 在Android应用开发过程中,对APK进行签名是一项重要的步骤。签名不仅可以确保应用程序来源的真实性和完整性,还能够确保应用更新时是由同一个开发者发布。本文将详细介绍如何生成Android ...

    android apk打包

    ### Android APK 打包与签名详解 #### 一、引言 随着移动互联网的发展,Android 成为了最受欢迎的移动操作系统之一。对于开发者来说,了解如何正确地进行 APK 打包和签名至关重要,因为这是确保应用程序安全性和...

Global site tag (gtag.js) - Google Analytics