`

android平台开发下 密钥管理

阅读更多

android平台开发下 密钥管理

 

 

    在release模式下编译程序,在Package面版上按project右键,选择Android Tools>Export Application Package.或者你可以点击Manifest Editor, overview 页面上的“Exporting the unsigned .apk”连接 ,导出未签名apk文件。保存.apk文件之后,用Jarsigner及你自己的密钥给apk文件签名 ,如果没有密钥, 你可以用Keystore创建密钥和密锁。如果已经有一个密钥了,如公共密钥,就可以给.apk文件签名了。
Android程序的签名和Symbian类似都可以自签名(Self-signed),但是在Android平台中证书初期还显得形同虚设,平时开发时通过ADB接口上传的程序会自动被签有Debug权限的程序。需要签名验证在上传程序到Android Market上时大家都已经发现这个问题了。Android signed制作方法
  首先在Android开发时没有安装JDK的网友在Sun官方网站下载JDKhttp://www.java.net/download/jdk ... 6-p-12_sep_2008.exe,其实仅需要中的Keytool和Jarsigner。
详细的签名步骤:
第一步
C:\Program Files\Java\jdk1.6.0_10\bin>keytool -genkey -alias android123.keystore
-keyalg RSA -validity 20000 -keystore android123.keystore
输入keystore密码:[密码不回显]
再次输入新密码:[密码不回显]
您的名字与姓氏是什么?
  [Unknown]:  android123
您的组织单位名称是什么?
  [Unknown]:  www.android123.com.cn
您的组织名称是什么?
  [Unknown]:  www.android123.com.cn
您的组织名称是什么?
  [Unknown]:  www.android123.com.cn
您所在的城市或区域名称是什么?
  [Unknown]:  New York
您所在的州或省份名称是什么?
  [Unknown]:  New York
该单位的两字母国家代码是什么
  [Unknown]:  CN
CN=android123, OU=www.android123.com.cn, O=www.android123.com.cn, L=New York, ST
=New York, C=CN 正确吗?
  [否]:  Y
输入<android123.keystore>的主密码
        (如果和 keystore 密码相同,按回车):
其中参数-validity为证书有效天数,这里我们写的大些20000天。还有在输入密码时没有回显,只管输入就可以了,一般位数建议使用20位,最后需要记下来后面还要用,整个过程如图:

  接下来我们开始为apk文件签名了。
第二步
  执行下面这句jarsigner -verbose -keystore android123.keystore -signedjar android123_signed.apk android123.apk android123.keystore 就可以生辰签名的apk文件,这里输入文件android123.apk,最终生成android123_signed.apk为Android签名后的APK执行文件。下面提示输入的密码和keytool输入的一样就行了,如图:
 
  有关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 <参数>]] ... 主类文件和构造函数参数

   昵称:狂飞

                                                    QQ:18670340

                                                    MSN:zhaojun1717@hotmail.com

                                                    注意事项:本文均为作者个人编写如果纰漏

                                                    请给予指出,转载请标明出处;

分享到:
评论

相关推荐

    基于多云存储的Android密钥管理技术.pdf

    9. 文档贡献与研究价值:文章提出了创新的密钥管理技术,不仅对Android平台的安全研究做出了贡献,还为多云存储环境下的安全密钥管理提供了新的解决方案。这不仅对学术界有参考价值,也对实际Android应用开发中的...

    Android系统终端上不得不说的5个密钥

    以Widevine为例,它是Google开发的一种DRM解决方案,并在Android平台上得到了广泛应用。内容提供商将视频内容加密后发送给用户,同时还会提供一个由DRM Key加密的Device Key和由Device Key加密的Content Key。用户...

    android网络开发与应用实战详解源码

    在Android平台上进行网络开发是一项核心技能,特别是在构建功能丰富的移动应用程序时。《Android网络开发与应用实战详解》一书深入浅出地介绍了Android系统中如何实现网络通信,并提供了丰富的源码示例。这本书涵盖...

    Android-用于管理Android的不同API上的密钥生成密钥存储和加密

    本文将深入探讨Android中密钥管理和加密的相关知识点,并以"yakivmospan-scytale-b0d38fc"这个项目为例进行说明。 首先,我们需要理解的是Android中的密钥存储系统。在Android API Level 18及以上版本,Android引入...

    Android Studio开发实战:从零基础到App上线

    《Android Studio开发实战:从零基础到App上线》是一本旨在帮助初学者全面掌握Android应用开发的实战指南。书中的内容涵盖了从环境搭建、基本概念理解到实际项目开发的全过程,旨在让读者能够从无到有,独立完成一个...

    基于Android平台的移动位置服务的开发与实现

    开发Android地图应用,首先需要获取Google地图服务的开发密钥(API Key),这通常通过注册证书(certificates)并在Google地图开发者网站完成。获得开发密钥后,必须在AndroidManifest.xml文件中注册相关的权限,包括对...

    Google map 开发密钥

    MapView 是Android平台下用于显示Google Map的一个组件。示例代码如下: ```xml &lt;com.google.android.maps.MapView android:id="@+id/mapview" android:layout_width="match_parent" android:layout_height=...

    Unity Android平台开发技巧

    - **Eclipse及插件**:安装Eclipse IDE并添加相应的插件,如ADT (Android Development Tools),以便更好地进行Android开发。 - **Android文档与SDK获取**:访问[官方文档](http://developer.android.com)下载最新的...

    android地图开发及google地图密钥申请.pdf

    ### Android地图开发及Google地图密钥申请详解 #### 一、环境配置与准备工作 在进行Android地图开发之前,首先需要确保开发环境正确配置,并完成一些基础准备工作。 **1.1 JDK环境确认** - **步骤**: 打开...

    Android开发—知识点精讲10—Android六种核心安全机制-加密、密钥、签名与证书视频教程下载(8课程).txt

    本篇文章将详细介绍Android的六种核心安全机制:加密、密钥管理、数字签名、证书系统等,并通过具体的实例来帮助理解这些概念。 #### 二、加密技术 **1. 对称加密** 对称加密是一种加密方法,其中发送者和接收者...

    Android平台开发源码_在水一方时钟.rar

    标题中的“Android平台开发源码_在水一方时钟.rar”...总之,这份压缩包提供了一个完整的Android应用开发实例,可以帮助开发者理解Android应用的架构、组件、资源管理和发布流程,对于提升Android开发技能大有裨益。

    Android应用开发解密源码

    综上所述,这个压缩包涵盖了Android应用开发中的核心概念,从用户交互的Activity,到后台运行的Service,再到数据共享的ContentProvider,以及系统通信的BroadcastReceiver和线程管理。通过深入学习这些章节的源码,...

    Android studio开发和风天气.zip

    在本项目"Android studio开发和风天气.zip"中,我们主要关注的是如何使用Android Studio进行一个简单的天气查询应用的开发。这个应用具有显示全国各省天气信息、未来三天天气预报以及空气质量的功能,且支持离线查询...

    基于Java的密钥管理工具 Keytool-IUI.zip

    Java的密钥管理工具Keytool-IUI是Java开发人员在处理加密、安全通信以及数字证书时不可或缺的一个实用程序。Keytool-IUI是对Java标准版(JDK)自带的keytool命令行工具的一种增强,提供了更加用户友好的图形界面,...

    老罗android 百度地图开发源码

    开发者需要在百度地图开放平台注册获取API密钥,然后将SDK导入到Android Studio项目中,并在AndroidManifest.xml中添加相应的权限声明,如ACCESS_FINE_LOCATION用于获取用户精确位置,INTERNET用于网络通信等。...

    android wifi开发简单demo

    在Android平台上进行WiFi开发是一项常见的任务,特别是在构建与网络通信相关的应用程序时。"android wifi开发简单demo"这个项目提供了一个基础示例,帮助开发者理解如何在Android设备上管理和使用WiFi功能。下面我们...

    Android 开发骑行轨迹制作管理系统

    以上便是Android开发骑行轨迹制作管理系统所涉及的关键技术点,涵盖了从基础开发环境设置到复杂功能实现的全过程。每个环节都需要深入理解和实践,才能打造出一个高效、稳定且用户体验优秀的应用。

    Rockchip Android Widevine开发指南

    该开发指南主要面向软件工程师、硬件工程师和测试工程师,涉及的技术内容包括硬件要求、软件集成、密钥管理、测试流程等。 文档中的知识点主要可以分为以下几个方面: 1. 文档适用范围和目标读者 开发指南主要面向...

Global site tag (gtag.js) - Google Analytics