如何发布软件到Google PlayStore
2013-03-07 16:46
633 查看
就国内用户而言,主要有两种方式:跟Google申请(好像需要支付$25美刀);再就是通过cmd100(中国手机开发者联盟)进行发布
有钱的别人服务自然不会存在什么问题,这里主要描述一下如果通过cmd100进行发布。
1. 注册cmd100会员(www.cmd100.com)
本来很简单,但现在已经不开放注册服务了,需要邀请码才行;获取邀请码的方式:
关注其官方微薄(weibo.com/cmd100),每天会通过微薄放出10个邀请码(动作麻利些,慢了就被抢完了)
给其客服发邮件申请:support@cmd100.com
找已注册的用户邀请,比如我(zwang@ucrobotics.com)
2. 完善自己的资料,特别是“软件上传资格认证”(点击“CM平台2.2”链接就可以看到了)
3. 参照“GM软件发布流程介绍”进行发布即可,应严格按照上面的提示进行填写
4. 补充说明APK的签名
只有签名过的APK包才能发布到Goole PlayStore上,为何要签名呢,是为了防止别人同名称的软件包将你的软件包给替换掉了(手机里面安装的时候)。操作方法如下:
首先导出未签名的apk包,注意默认project/bin/目录下那个apk是不能用的,因为被系统默认进行了debug签名,而这种签名方式是不能上
传到Google PlayStore的,而且已经签名过(无论任何方式)的apk是不能再进行第二次签名的,会提示类似这种错误:
导出未签名apk包的方法:右键Project -> Android Tools -> Export Unsigned Application Package,然后选个位置保存(如保存为hello_unsigned.apk)
进入hello_unsigned.apk所在的目录,执行密钥生成命令:
表示产生密钥文件的名字为hello.keystore(名称可以自由修改,但后缀不能变),有效期为20000天(这里设置的比较大,可自行修改)
然后进行认证签名:
hello.keystore为前面生成的密钥文件,hello_signed.apk为签名后的apk,hello_unsingned.apk为源apk
附上keytool参数以及jarsigner参数:
参考连接:
【1】www.oschina.net/code/snippet_204593_7816
【2】my.oschina.net/ykai/blog/37220
有钱的别人服务自然不会存在什么问题,这里主要描述一下如果通过cmd100进行发布。
1. 注册cmd100会员(www.cmd100.com)
本来很简单,但现在已经不开放注册服务了,需要邀请码才行;获取邀请码的方式:
关注其官方微薄(weibo.com/cmd100),每天会通过微薄放出10个邀请码(动作麻利些,慢了就被抢完了)
给其客服发邮件申请:support@cmd100.com
找已注册的用户邀请,比如我(zwang@ucrobotics.com)
2. 完善自己的资料,特别是“软件上传资格认证”(点击“CM平台2.2”链接就可以看到了)
3. 参照“GM软件发布流程介绍”进行发布即可,应严格按照上面的提示进行填写
4. 补充说明APK的签名
只有签名过的APK包才能发布到Goole PlayStore上,为何要签名呢,是为了防止别人同名称的软件包将你的软件包给替换掉了(手机里面安装的时候)。操作方法如下:
首先导出未签名的apk包,注意默认project/bin/目录下那个apk是不能用的,因为被系统默认进行了debug签名,而这种签名方式是不能上
传到Google PlayStore的,而且已经签名过(无论任何方式)的apk是不能再进行第二次签名的,会提示类似这种错误:
jarsigner: 无法对 jar 进行签名: java.util.zip.ZipException: invalid entry compressed size (expected 663 but got 667 bytes)
导出未签名apk包的方法:右键Project -> Android Tools -> Export Unsigned Application Package,然后选个位置保存(如保存为hello_unsigned.apk)
进入hello_unsigned.apk所在的目录,执行密钥生成命令:
$ keytool -genkey -alias hello.keystore -keyalg RSA -validity 20000 -keystore hello.keystore 输入keystore密码: //该密码下条命令要用到 再次输入新密码: 您的名字与姓氏是什么? [Unknown]: wzc0066 您的组织单位名称是什么? [Unknown]: ucrobotics 您的组织名称是什么? [Unknown]: ucrobotics 您所在的城市或区域名称是什么? [Unknown]: beijing 您所在的州或省份名称是什么? [Unknown]: beijing 该单位的两字母国家代码是什么 [Unknown]: cn CN=wzc0066, OU=ucrobotics, O=ucrobotics, L=beijing, ST=beijing, C=cn 正确吗? [否]: Y 输入<ucrconsole.keystore>的主密码 (如果和 keystore 密码相同,按回车):
表示产生密钥文件的名字为hello.keystore(名称可以自由修改,但后缀不能变),有效期为20000天(这里设置的比较大,可自行修改)
然后进行认证签名:
$ jarsigner -verbose -keystore hello.keystore -signedjar hello_signed.apk hello_unsingned.apk hello.keystore 输入密钥库的口令短语: //前面设置的密码 正在添加: META-INF/MANIFEST.MF 正在添加: META-INF/UCRCONSO.SF 正在添加: META-INF/UCRCONSO.RSA 正在签名: res/layout/srv1about.xml 正在签名: res/layout/srv1connect.xml 正在签名: res/layout/srv1console.xml 正在签名: res/layout/srv1settings.xml 正在签名: AndroidManifest.xml ... ...
hello.keystore为前面生成的密钥文件,hello_signed.apk为签名后的apk,hello_unsingned.apk为源apk
附上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 <参数>]] ... 主类文件和构造函数参数
参考连接:
【1】www.oschina.net/code/snippet_204593_7816
【2】my.oschina.net/ykai/blog/37220
相关文章推荐
- Android Market google play store帐号注册方法流程 及发布应用注意事项
- Android Market google play store帐号注册方法流程 及发布应用注意事项
- 在浏览器中下载Google play store软件
- 如何定位Google Play Store无法连接问题
- 关于如何在Google Play Store 购买付费APP
- Android Market google play store帐号注册方法流程 及发布应用注意事项【转载】
- Google Play Store如何换区
- Android Market google play store帐号注册方法流程 及发布应用注意事项
- Android Market google play store帐号注册方法流程 及发布应用注意事项
- C#如何发布项目 发布软件
- Google发布IM软件--Talk
- 如何将IPhone应用软件发布到App Store的
- 学习笔记6-Android查看应用输出的错误信息 如何部署应用到真实手机 发布软件
- 如何打包发布基于Qt4 Windows的软件
- Google Play Store&nbsp…
- Google Play Store
- Google发布Linux下的Picasa软件
- Android国行手机使用Google Play Store