终端开发

Android开发之FileProvider相关知识 Android 权限 及设置描述信息 局域网开启 Android ADB 无线调试 安卓开发那些事之开发规范 安卓组件化之组件通信及拦截 安卓开发那些事之版本管理 安卓组件化之持续集成与自动构建 安卓组件化之组件调试和运行 安卓组件化之组件管理(导入、依赖、升级) 安卓组件化之框架设计 安卓开发那些事总纲 Android Textview 对HTML 的支持 appium 爬坑之基于 Chromedriver 测试 Android webview Linux 搭建 Android 编译构建环境 appium爬坑之iMac上基于appium多设备并发测试 appium爬坑之iMac上appium环境搭建及使用真机测试Android项目简介 H5页面通过指定Schema拉起Android应用 Android JSBridge简介 Gradle插件开发系列之发布gradle插件到开源库 Gradle插件开发系列之开发第一个gradle插件 Gradle插件开发系列之gradle插件调试方法 Gradle插件开发系列之总纲 一款检查Gradle依赖配置是否冲突的插件 记一次升级Android Gradle Plugin后databing编译报错填坑经历 iMac上 Xcode 相关设置及常见问题 iOS开发 -- 首次使用Xcode运行iOS项目代码 使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 Android安装包精简系列之资源精简 Android安装包精简系列之图片优化 Android安装包精简系列之为什么要优化精简安装包 Android安装包精简系列(总纲) Android安装包精简系列之图标转字体 Gradle 相关资料汇总 Android编译常见错误解决 Android编译编译速度提升 终端基于gradle的开源项目运行环境配置指引 制作终端产品演示的gif 一个关于APK Signature Scheme v2签名的神奇bug定位经历 如何随apk一起打包并使用SQLite SDK热更之gradle插件(如何在SDK代码中自动插桩及如何生成补丁包) 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 SDK热更系列之概述(持续整理编辑中~) SDK热更系列之SDKHotfix待优化点 Android 终端开发相关的一些神图(持续更新) SDK热更系列之Demo项目介绍概述 SDK热更系列之Demo体验方法 SDK热更系列之如何获取应用在当前设备上的so对应的指令集 Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 ADB命令系列之再说ADB 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 ADB命令系列之 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书)及命令行获取 keystore 公钥等信息 Robotium二三事-Android自动化测试系列(二) Robotium介绍-Android自动化测试系列(一) Android开发中遇到的那些坑 Eclipse使用中部分经验总结 Android中关于Nativa编译(NDK、JNI)的一些问题 Android简单实现的多线程下载模块 Android内存耗用之VSS/RSS/PSS/USS ADB命令系列之 Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 ADB命令系列之 Base Command Android Log的那些坑…………

开发工具

Linux JDK 安装、卸载、路径查看 替换Jcenter,发布开源代码到 Sonatype Maven Central 使用 gitstats 分析代码仓库 使用 Jekyll 搭建技术博客并部署到 CentOS 服务器 开发中常用的文档管理、云端笔记等效率工具介绍 iMac(OS X)常用图片处理工具介绍 使用 Octopress 搭建技术博客并使用腾讯云静态网站托管 使用腾讯云静态网站托管个人博客 使用 Jekyll 搭建技术博客 iMac上安装Python2.7 和 Python3 iMac 使用自带的 Apache 启用本地web服务 发布开源代码到jcenter Gradle环境变量那些事 iMac搭建jekyll本地环境 iMac(OS X)开发和使用中经验汇总(持续更新) iMac配置基于crontab的定时任务 iMac配置支持读取NTFS硬盘 新iMac机器装机及开发环境搭建攻略 git常用命令整理(已包括branch、tag等持续更新~) iMac使用过程中的简单故障解决 iMac上RubyGems相关的问题汇总 开发中常用的一些Chrome插件介绍 iMac(OS X)日常开发中各种代理设置方法汇总(shell、Android Studio、gem、npm) Markdown格式优化及使用技巧 iMac下制作含透明度图片及判断图片透明度 iMac(OS X)中设置大小写敏感的分区并切换 Linux & MacOS中一些常用命令备忘 iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 iMac(OS X)El Capitan 更新遇到的那些坑 vi常用命令 iMac(OS X)常用开发工具介绍 iMac(OS X)不可或缺的套件管理器 —— Homebrew 开发环境通用设置 windows中一些常用命令备忘 问题定位之快速模拟请求 Ant中的SVN 使用 Markdown语法简介 SVN 常用命令

标签

android 50

ADB快捷输入法 - AAF 开发中图片图标处理常用工具资源 Linux 搭建 Android 编译构建环境 H5页面通过指定Schema拉起Android应用 Android编译常见错误解决 一个关于APK Signature Scheme v2签名的神奇bug定位经历 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 Android 终端开发相关的一些神图(持续更新) Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 iMac(OS X)El Capitan 更新遇到的那些坑 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 ADB命令系列之再说ADB 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 ADB命令系列之 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书)及命令行获取 keystore 公钥等信息 Eclipse使用中部分经验总结 Android内存耗用之VSS/RSS/PSS/USS ADB命令系列之 Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 ADB命令系列之 Base Command Android Log的那些坑…………

tags 53

替换Jcenter,发布开源代码到 Sonatype Maven Central Android开发之FileProvider相关知识 子勰开源项目展示 照片整理系之视频归档整理方案 使用 gitstats 分析代码仓库 Android 权限 及设置描述信息 局域网开启 Android ADB 无线调试 安卓开发那些事之开发规范 安卓组件化之组件通信及拦截 安卓开发那些事之版本管理 安卓组件化之持续集成与自动构建 安卓组件化之组件调试和运行 安卓组件化之组件管理(导入、依赖、升级) 安卓组件化之框架设计 安卓开发那些事总纲 Android Textview 对HTML 的支持 使用 Jekyll 搭建技术博客并部署到 CentOS 服务器 2018年春节仙本那海岛游行程规划 照片整理系列之单次整理流程 照片整理系列之整理及归档的总体方案 使用 Octopress 搭建技术博客并使用腾讯云静态网站托管 使用腾讯云静态网站托管个人博客 使用 Jekyll 搭建技术博客 颜色透明度对照表 Android JSBridge简介 Gradle插件开发系列之发布gradle插件到开源库 Gradle插件开发系列之开发第一个gradle插件 Gradle插件开发系列之gradle插件调试方法 发布开源代码到jcenter Gradle环境变量那些事 Gradle插件开发系列之总纲 一款检查Gradle依赖配置是否冲突的插件 记一次升级Android Gradle Plugin后databing编译报错填坑经历 服务器 迁移到 腾讯云 记录 2018年春节沙巴仙本那海岛游 聚会桌游助手 nodejs入门之后台服务的几种启动方式 nginx下多域名配置示例 nodejs入门之连接mysql mysql迁移之新建用户、备份还原数据库 iMac配置基于crontab的定时任务 iOS开发 -- 首次使用Xcode运行iOS项目代码 新iMac机器装机及开发环境搭建攻略 旅行中不可或缺的软件 iMac上RubyGems相关的问题汇总 接口设计六大原则 Canvas上更高效的画SVG 微信小程序开发之SVG的使用 旅行出行前准备列表 使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 2017年端午川西滇北香格里拉环线(近200张图慎点) 照片整理系列之基于命令行的照片整理及查看工具 Gradle 相关资料汇总

Android签名校验机制(数字证书)及命令行获取 keystore 公钥等信息

「 终端开发 」 ——  2015年02月10日

之前有多个游戏遇到关于签名错误的问题,加上有些游戏开发不熟悉Android签名校验的机制以及打包的方法,就专门总结了一下,现在整理一下。 首先放上官方文档链接:http://developer.android.com/tools/publishing/app-signing.html

什么是签名

就是只有信息的发送者才能产生的别人无法伪造的一段数字串,这段数字串同时也是对信息的发送者发送信息真实性的一个有效证明。数字签名是个加密的过程,数字签名验证是个解密的过程。

为什么有签名

  • 最简单直接的回答: 系统要求的。

  • 通俗的解答:

    Android系统要求每一个Android应用程序必须要经过数字签名才能够安装到系统中,也就是说如果一个Android应用程序没有经过数字签名,是没有办法安装到系统中的!

  • 装逼的解答:

    在Android 系统中,所有安装到系统的应用程序都必有一个数字证书,此数字证书用于标识应用程序的作者和在应用程序之间建立信任关系,如果一个permission的protectionLevel为signature,那么就只有那些跟该permission所在的程序拥有同一个数字证书的应用程序才能取得该权限。

签名怎么来

数字证书的私钥保存在程序开发者的手中。Android将数字证书用来在应用程序的作者和应用程序之间建立信任关系,不是用来决定最终用户可以安装哪些应用程序。这个数字证书并不需要权威的数字证书签名机构认证,它只是用来让应用程序包自我认证的。

签名的两种模式

调试模式(debug mode)

在调试模式下,ADT会自动的使用debug密钥为应用程序签名,因此我们可以直接运行程序。

  • debug密钥:一个名为debug.keystore的文件,android默认的debug.keystore的信息如下:

      Keystore name: “debug.keystore”
      Keystore password: “android”
      Key alias: “androiddebugkey”
      Key password: “android”
      CN: “CN=Android Debug,O=Android,C=US”
    
  • 存放位置:C:\Users\用户名.android\debug.keystore

debug签名的两个风险:

  1. debug签名的应用程序不能在Android Market上架销售,它会强制你使用自己的签名;
  • debug.keystore在不同的机器上所生成的可能都不一样,就意味着如果你换了机器进行apk版本升级,那么将会出现程序不能覆盖安装的问题。

发布模式(release mode)

发布程序时,开发者需要使用自己的数字证书给apk包签名。使用自己的数字证书给APK签名有两种方法。将在下文描述。

私钥生成

私钥目前主要是通过 keytool 生成,事例如下:

  • 生成命令:

      keytool -genkey -keystore debug.keystore -alias bihe0832 -keypass android -keyalg RSA -validity 40000
    
  • 常用参数含义:

    • genkey 在用户主目录中创建一个默认文件”.keystore”
    • alias 产生别名 每个keystore都关联这一个独一无二的alias,这个alias通常不区分大小写
    • keystore 指定密钥库的名称(产生的各类信息将不在.keystore文件中)
    • keyalg 指定密钥的算法 (如 RSA DSA,默认值为:DSA)
    • list 显示密钥库中的证书信息 keytool -list -v -keystore 指定keystore -storepass 密码
    • v 显示密钥库中的证书详细信息
  • 非常用参数含义:

    • validity 指定创建的证书有效期多少天(默认 90)
    • keysize 指定密钥长度 (默认 1024)
    • storepass 指定密钥库的密码(获取keystore信息所需的密码)
    • keypass 指定别名条目的密码(私钥的密码)
    • dname 指定证书发行者信息 其中: “CN=名字与姓氏,OU=组织单位名称,O=组织名称,L=城市或区域名 称,ST=州或省份名称,C=单位的两字母国家代码”
    • export 将别名指定的证书导出到文件 keytool -export -alias 需要导出的别名 -keystore 指定keystore -file 指定导出的证书位置及证书名称 -storepass 密码
    • file 参数指定导出到文件的文件名
    • delete 删除密钥库中某条目 keytool -delete -alias 指定需删除的别 -keystore 指定keystore – storepass 密码
    • printcert 查看导出的证书信息 keytool -printcert -file g:\sso\michael.crt
    • keypasswd 修改密钥库中指定条目口令 keytool -keypasswd -alias 需修改的别名 -keypass 旧密码 -new 新密码 -storepass keystore密码 -keystore sage
    • storepasswd 修改keystore口令 keytool -storepasswd -keystore g:\sso\michael.keystore(需修改口令的keystore) -storepass pwdold(原始密码) -new pwdnew(新密码)
    • import 将已签名数字证书导入密钥库 keytool -import -alias 指定导入条目的别名 -keystore 指定keystore -file 需导入的证书

命令行信息查看

查看基本信息

  • 查看命令:

      keytool -list -v -keystore debug.keystore	
    
  • 使用事例:

      ➜  AndroidAppFactory git:(master) keytool -list -v -keystore debug.keystore
      输入密钥库口令:
      密钥库类型: JKS
      密钥库提供方: SUN
    	
      您的密钥库包含 1 个条目
    	
      别名: androiddebugkey
      创建日期: 2015年1月19日
      条目类型: PrivateKeyEntry
      证书链长度: 1
      证书[1]:
      所有者: CN=Android Debug, O=Android, C=US
      发布者: CN=Android Debug, O=Android, C=US
      序列号: 54bc748d
      生效时间: Mon Jan 19 11:05:49 CST 2015, 失效时间: Wed Jan 11 11:05:49 CST 2045
      证书指纹:
           SHA1: F1:61:47:EC:C2:98:F4:F2:ED:DE:B5:5E:C9:4B:62:92:2F:52:BE:2C
           SHA256: 3A:DB:9E:16:EE:E3:84:81:63:91:F7:CE:A0:FF:F0:BF:24:8F:F2:C3:00:EA:06:97:2B:83:8B:AA:95:FF:48:8A
      签名算法名称: SHA1withRSA (弱)
      主体公共密钥算法: 1024 位 RSA 密钥 (弱)
      版本: 3
    	
    	
      *******************************************
      *******************************************
    

查看公私钥

  • 查看命令:

      keytool -list -rfc --keystore debug.keystore | openssl x509 -inform pem -pubkey
    
  • 使用事例:

      ➜  AndroidAppFactory git:(master) keytool -list -rfc --keystore ./debug.keystore | openssl x509 -inform pem -pubkey
      输入密钥库口令:  android
      -----BEGIN PUBLIC KEY-----
      MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCU1yjobRCWKk70XfM3lYM/Vsb9
      eTNs8wavDOrH2VHi471/WtW+vuvXWdeF2NmvciVU7y+E6qf561rA7hdx5iDi4z7K
      vvCri6ySiXM7Dq+4UBL3FT1V4kqLtvzjNIKs2Cp2HIRI/DAwgD6lOKseApSPj5Kw
      iFxe35iwTAYDr9EykQIDAQAB
      -----END PUBLIC KEY-----
      -----BEGIN CERTIFICATE-----
      MIIB5TCCAU6gAwIBAgIEVLx0jTANBgkqhkiG9w0BAQUFADA3MQswCQYDVQQGEwJV
      UzEQMA4GA1UEChMHQW5kcm9pZDEWMBQGA1UEAxMNQW5kcm9pZCBEZWJ1ZzAeFw0x
      NTAxMTkwMzA1NDlaFw00NTAxMTEwMzA1NDlaMDcxCzAJBgNVBAYTAlVTMRAwDgYD
      VQQKEwdBbmRyb2lkMRYwFAYDVQQDEw1BbmRyb2lkIERlYnVnMIGfMA0GCSqGSIb3
      DQEBAQUAA4GNADCBiQKBgQCU1yjobRCWKk70XfM3lYM/Vsb9eTNs8wavDOrH2VHi
      471/WtW+vuvXWdeF2NmvciVU7y+E6qf561rA7hdx5iDi4z7KvvCri6ySiXM7Dq+4
      UBL3FT1V4kqLtvzjNIKs2Cp2HIRI/DAwgD6lOKseApSPj5KwiFxe35iwTAYDr9Ey
      kQIDAQABMA0GCSqGSIb3DQEBBQUAA4GBAEYAcZE2H9kwJELwIOSB1ezTTvYGvdZw
      R2gYm1gnQhWtUxGS05iewhTv8GynPWxuRVyEAOZdrIy1EP+ToPlyD9COgU61pyEs
      bcWbp7WFBxC/+V0XazOJ0PbPpECTzJLYnd/By7rQK8SkkVimm9rufiTnZCdzKQgZ
      +WvQ/Jv7n2cU
      -----END CERTIFICATE-----
    

APK信息查看

如果要使用APK 查看加密信息,可以参考下面的链接:应用信息及Keystore信息获取 - AAF

签名方法

使用keytool签名

目前使用keytool签名有两种方式,一种是java提供的jarsigner,另一种是安卓官方提供的apksigner,这里分别介绍一下。不过需要注意的是目前Android已经在逐渐淘汰基于 jarsigner 的 Android V1 签名模式,因此如非必需,建议使用基于 apksigner的 Android V2 签名方式签名apk。关于 Android V2 签名的更多文章,请参考个人的另一篇文章:关于Android的APK Signature Scheme v2签名相关的资料汇总

使用jarsigner 签名

  • 签名命令:

     jarsigner -verbose -keystore bihe0832.keystore -signedjar agsdkdemo_signed.apk  -digestalg SHA1 -sigalg SHA1withDSA agsdkdemo.apk bihe0832 -storepass mypassword
    
  • 参数含义:

    • verbose: 输出签名的详细信息
    • -keystore bihe0832.keystore: 密钥库位置
    • -signedjar agsdkdemo_signed.apk:签名后产生的文件
    • -digestalg SHA1 -sigalg SHA1withDSA:私钥算法
    • agsdkdemo.apk:要签名的文件demo.apk
    • bihe0832:私钥的alias
    • -storepass mypassword:私钥密码,其中mypassword即为密码
  • 注意事项:android工程的bin目录下的demo.apk默认是已经使用debug用户签名的,所以不能使用上述步骤对此文件再次签名。正确步骤应该是:在工程点击右键->Anroid Tools-Export Unsigned Application Package导出的apk采用上述步骤签名。

使用apksigner 签名

  • 签名命令:

     $ANDROID_HOME/build-tools/25.0.1/apksigner sign --ks ~/lib/bihe0832.keystore ./debug-ysdk.apk
    			
     $ANDROID_HOME/build-tools/25.0.1/apksigner sign --ks ~/lib/bihe0832.keystore --out ./debug-ysdk-singned.apk --ks-pass pass:mypassword ./debug-ysdk.apk
    
  • 参数含义:

    • sign :给应用签名
    • --ks ~/lib/bihe0832.keystore: 密钥库位置
    • --out ./debug-ysdk-singned.apk: 签名后应用
    • --ks-pass pass:mypassword: 文字格式的私钥密码,其中mypassword即为密码
    • ./debug-ysdk.apk: 要签名的应用
  • 注意事项: apksigner是Android官方提供的签名及校验工具,从Android SDK Build Tools的24.0.3版本开始支持,具体路径在SDK目录的build-tools目录下。

使用Eclipse直接导出带签名的APK

Eclipse直接能导出带签名的最终apk,非常方便,推荐使用,步骤如下:

  1. 导出

    导出

  • 选择工程:选择你要导出apk的工程

  • 创建密钥库keystore,输入密钥库导出位置和密码,要记住密码

    创建密钥库keystore

  • 填写密钥库信息,填写一些apk文件的密码,使用期限和组织单位的信息

  • 输入生成带签名的apk文件的位置。

常见问题

  1. jarsigner: 找不到XXXX的证书链。XXXX必须引用包含私有密钥和相应的公共密钥证书链的有效密钥库密钥条目。

    出现该错误是因为在命令输入的最后一个参数填写的是签名私钥的alias,而不是私钥的文件名称

  2. jarsigner: 无法对 jar 进行签名: java.util.zip.ZipException: invalid entry compressed size (expected 19384 but got 19942 bytes)

    出现该错误的原因是因为对一个已经使用DEBUG权限的数字签名的包,使用jarsigner再次签名导致的,建议用V2重新签名或者导出一个未签名的apk重新签名即可,如果一定要对当前包重新签名,可以选择将文件修改为.zip后缀,然后解压缩,删除META-INF目录,然后再次压缩为.zip并修改扩展名为.apk后再次签名

  3. jarsigner 错误: java.security.NoSuchAlgorithmException: unrecognized algorithm name: RSAwithDSA

    出现该错误的原因是私钥算法与签名算法(命令中的-sigalg 参数的值)不兼容,直接使用keytool去查看私钥使用的算法修改即可,命令示例如下:

     ➜  readhub git:(master) keytool -list -v -keystore bihe0832.keystore
     输入密钥库口令:
     ……
    	
     证书指纹:
         ……
          签名算法名称: SHA1withDSA
     ……
    
  4. jarsigner: 无法对 jar 进行签名: 无法对jar进行签名:java.util.zip.ZipException: invalid entry compressed size (expected xxx but got xxx bytes)

    出现该错误的原因是由于资源文件造成的,对于android开发来说应该检查res文件夹中的文件,逐个排查。当然也可以可以通过升级系统的JDK和JRE版本来解决。

  5. 安装apk过程中出现:adb: failed to install 2.apk: Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES: Failed to collect certificates from XXX.apk: Attempt to get length of null array]

    使用adb安装时出现该错误是因为应用没有签名,需要先对apk签名之后再尝试安装

  6. 安装apk过程中出现:adb: failed to install test.apk: Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES: Failed to collect certificates from XXX.apk: META-INF/CERT.SF has invalid digest for XXX.xml in XXX.apk]

    出现该的原因是由于使用jarsigner 方式签名时JDK的版本问题造成的,可以通过升级系统的JDK和JRE版本来解决。

  7. 安装apk过程中出现:adb: failed to install test-singend.apk: Failure [INSTALL_FAILED_UPDATE_INCOMPATIBLE: Package com.bihe0832.getsignature signatures do not match the previously installed version; ignoring!]

    出现该错误的原因是因为设备上已经安装了一个同包名但是签名并不一致的apk,需要卸载原有apk重新安装新签名的apk。

  8. 安装apk过程中出现:adb: failed to install test-singend.apk: Failure [INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES]

    出现该错误的原因是因为设备上已经安装了一个同包名但是签名并不一致的apk,并且已经安装的应用使用Android的debug签名文件来签名,即将安装的应用使用自定义签名文件签名,需要卸载原有apk重新安装新签名的apk。

参考文章:

  1. http://www.cnblogs.com/wanqieddy/p/3556060.html
  2. http://www.tttabc.com/android/keytool-keystore-jarsigner-apk.htm
  3. http://yangguangfu.iteye.com/blog/723182
  4. 关于Android的APK Signature Scheme v2签名相关的资料汇总

赞赏

取消
微信扫一扫,赞赏子勰
扫码支持
屌丝程序猿,鸡血攻城狮!努力学技术,潜心做精品!