为什么每次微信支付验证签名失败的时候一直显示zipalign失败

为什么每次签名的时候一直显示zipalign失败_mt管理器吧_百度贴吧
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&签到排名:今日本吧第个签到,本吧因你更精彩,明天继续来努力!
本吧签到人数:0可签7级以上的吧50个
本月漏签0次!成为超级会员,赠送8张补签卡连续签到:天&&累计签到:天超级会员单次开通12个月以上,赠送连续签到卡3张
关注:13,994贴子:
为什么每次签名的时候一直显示zipalign失败
接着显示签名成功
安装有没有变化
贴吧热议榜
使用签名档&&
保存至快速回贴下次自动登录
现在的位置:
& 综合 & 正文
Android优化工具之——Zipalign
Zipalign优化工具是Android SDK中自带的apk优化工具,开发者在上传应用到Google Play的时候相信都遇到过“您上传的Apk没有经过Zipalign处理”的失败提示,显而易见Google对Zipalign工具的重视,那么Zipalign到底有什么用了?
说白了,Zipalign就是一个对Apk文件进行存档对齐的优化工具,它的目的是确保所有的未压缩数据都从文件的开始位置以指定的对齐方式排列。尤其是.apk压缩包中的图片资源和未加工处理的相关文件,对齐的方式是以4字节对齐。其好处是能够减少应用的RAM内存资源消耗。Google的Android开发文档中特别之处在发布应用到最终客户之前务必使用Zipalign工具对你的.apk文件进行优化。如果你使用Eclipse中的ADT插件工具导出签名应用的话,其将会自动优化你的应用无需额外使用zipalign工具。或者是你的工程文件ant.properties中制定了密钥存储的路径或密钥的别名,构造脚本也将自动对apk文件进行Zipalign优化处理。、
1. 对已有的APK文件进行Zipalign处理
zipalign [-f] [-v] &alignment& infile.apk outfile.apk
infile.apk表示输入的apk文件,outfile.apk表示输出的apk文件(文件名可以自己制定)。
alignment:表示指定的对应字节数,是一个整数且必须指定为4。
2. 检测已有的APK文件是否进行了Zipalign处理
zipalign -c -v &alignment& existing.apk
-f : overwrite existing outfile.zip
-v : verbose output
-c : confirm the alignment of the given file
Zipalign工具位于SDK的tools目录中,以windows操作系统为例,在运行中输入cmd进去Dos操作界面,用cd命令跳转到Zipalign的目录,输入Zipalign的相应命令就能使用其功能了。
&&&&推荐文章:
【上篇】【下篇】Android 签名详解 - 阿福 - ITeye技术网站
系统中,所有
系统的应用程序都必有一个数字证书,此数字证书用于标识应用程序的作者和在应用程序之间建立信任关系,如果一个
permission的protectionLevel为signature,那么就只有那些跟该permission所在的程序拥有同一个数字证书的应
用程序才能取得该权限。Android使用Java的数字证书相关的
给apk加盖数字证书,要理解android的数字证书,需要先了解以下数字证书的概念和java的数字证书机制。Android系统要求每一个安装进系
统的应用程序都是经过数字证书签名的,数字证书的私钥则保存在程序开发者的手中。Android将数字证书用来标识应用程序的作者和在应用程序之间建立信
任关系,不是用来决定最终用户可以安装哪些应用程序。这个数字证书并不需要权威的数字证书签名机构认证,它只是用来让应用程序包自我认证的。(文/
)一:同一个开发者的多个程序尽可能使用同一个数字证书
,这可以带来以下好处。
(1)有利于程序升级,当新版程序和旧版程序的数字证书相同时,Android系统才会认为这两个程序是同一个程序的不同版本。如果新版程序和旧版程序的数字证书不相同,则Android系统认为他们是不同的程序,并产生冲突,会要求新程序更改包名。
(2)有利于程序的模块化设计和开发。Android系统允许拥有同一个数字签名的程序运行在一个进程中,Android程序会将他们视为同一个程序。所以开发者可以将自己的程序分模块开发,而用户只需要在需要的时候下载适当的模块。
可以通过权限(permission)的方式在多个程序间共享数据和代码。Android提供了基于数字证书的权限赋予机制,应用程序可以和其他的程序共
享概功能或者数据给那那些与自己拥有相同数字证书的程序。如果某个权限(permission)的protectionLevel是signature,
则这个权限就只能授予那些跟该权限所在的包拥有同一个数字证书的程序。
在签名时,需要考虑数字证书的有效期
(1)数字证书的有效期要包含程序的预计生命周期,一旦数字证书失效,持有改数字证书的程序将不能正常升级。
(2)如果多个程序使用同一个数字证书,则该数字证书的有效期要包含所有程序的预计生命周期。
(3)Android Market强制要求所有应用程序数字证书的有效期要持续到日以后。二:Android数字证书包含以下几个要点:
(1)所有的应用程序都必须有数字证书
,Android系统不会安装一个没有数字证书的应用程序
(2)Android程序包使用的数字证书可以是自签名的,不需要一个权威的数字证书机构签名认证
(3)如果要正式
一个Android ,必须使用一个合适的私钥生成的数字证书来给程序签名
,而不能使用adt
生成的调试证书来发布。
(4)数字证书都是有有效期
的,Android只是在应用程序安装的时候才会检查证书的有效期。如果程序已经安装在系统中,即使证书过期也不会影响程序的正常功能。
(5)Android使用标准的java工具 Keytool and Jarsigner
来生成数字证书,并给应用程序包签名。
(6)使用zipalign
系统不会安装运行任何一款未经数字签名的apk程序,无论是在模拟器上还是在实际的物理设备上。Android的开发工具(ADT插件和Ant)都可以协
助开发者给apk程序签名,它们都有两种模式:调试模式(debug mode)和发布模式(release mode)。
在调试模式下,android的开发工具会在每次编译时使用调试用的数字证书给程序签名,开发者无须关心。
当要发布程序时,开发者就需要使用自己的数字证书给apk包签名,可以有两种方法。
(1)在命令行下使用JDK中的和Keytool(用于生成数字证书)和Jarsigner(用于使用数字证书签名)来给apk包签名。
(2)使用ADT Export Wizard进行签名(如果没有数字证书可能需要生成数字证书)。
三;两种签名方式
第一种签名方式,
使用Keytool和Jarsigner给程序签名(
用于1.5以下版本
命令:keytool -genkey -v -keystore android.keystore -alias android -keyalg RSA -validity 20000
命令中,-keystore ophone.keystore 表示生成的证书,可以加上路径(默认在用户主目录下);-alias ophone
表示证书的别名是ophone;-keyalg RSA 表示采用的RSA算法;-validity 20000表示证书的有效期是20000天。
(80.80 K) 22:48:46
此时,我们会在互用主目录下看到ophone.keystore,即我们刚刚创建的证书。
第二种签名方式:现在介绍android 1.5及更新版本的apk签名方式
1,打开Eclipse-&选择你要签名的项目-&右击-&android tools-&Export signed Application package...
2,跳出窗口
3,project checks 如果核对项目名没有问题的话 点击 Next
然后跳出keystore selection 如果是已经存在keystore的文件就选择然后next 输入keystore的密码进行签名。
如果没有的话选择 create new keystore 然后选择 keystore 保存的位置,设置keystore的密码,点击Next。
4.填写keystore的基本信息,如,别名,密码,有效期,姓名,组织,组织名称,所在城市,所在省份,国家等,点击Next
5.选择被签名后的APK保存位置。点击finish。
6.就可以在你保存的位置中找到相应的被签名后的APK文件。
以上的签名只有在ANDROID1.5以及以后的版本适用。谢谢。
希望对大家有帮助,谢谢。
浏览 104230
yangguangfu
浏览: 1260334 次
来自: 北京
aclululu 写道最后一个表示不解,既然已经New Jia ...
aclululu 写道最后一个表示不解,既然已经New Jia ...
写的不错,是男人的话,瞬间就能理解了。
最后一个表示不解,既然已经New JiaShi出来了,为毛在装 ...

我要回帖

更多关于 签名失败 的文章

 

随机推荐