救救我的Android app吧

这篇文章应该屏蔽老板,因为我一不小把Google Play上的app搞坏了。

起因

前些日子搭建了一套新的CI/CD工具用来分发app,经过测试也都没毛病。转眼间就release了,等我从Google play上进行覆盖安装的时候,竟然发现无法覆盖安装!我第一时间便想到了apk签名问题,去Play console一看果不其然,不知道为什么Signing by Google Play已被设置为开启状态:

瞬间就慌了有没有?明天还能上班不了?

我赶紧问了问Gemini能不能把Signing by Google Play关掉,它直接告诉放弃这个想法吧。

使用Google Play签名的方式自然有它的好处,比如说再也不用担心签名文件的丢失了。

好处是有的,但这么一搞,对于我来说坏处更多。

  • 旧的用户只能卸载了重装
  • 内部测试都是使用CI/CD打包出来的版本,这对一些需要验证SHA1的第三方sdk非常不友好,比如Facebook 登录不了,因为有的第三方sdk是没有办法像GCP一样支持同一个包名用不同SHA1的

这怎么办?

使用PEPK进行密钥升级

这种情况Google当然是想到了。我们可以选择去升级我们的密钥,鉴于我没有根帐号,所以以下的贴图有限,而且还是英文的。

第一步:请求升级密钥

先去Test and release - App integrity,找到Play app signing,然后点击右侧的Settings

我这个帐号是没权限的,有权限的下面会是一行蓝色的小字Request key upgrade:

第二步:下载工具(pepk.jar)

下面有几个选项,请选择"Upload a new app signing from Java KeyStore":

谨慎一点哦,这个签名好像一年只能更新一次或者终身只能更一次。先是下载公钥(Download encryption public key),然后下载pepk.jar(Download PEPK tool)。

然后在终端运行以下命令:

bash 复制代码
java -jar pepk.jar --keystore=foo.keystore --alias=foo --output=output.zip  --signing-keystore=uploadkey.keystore --signing-key-alias=upload-key-alias --rsa-aes-encryption --encryption-key-path=/path/to/encryption_public_key.pem
  • --keystore=foo.keystore 已有的密钥
  • --alias=foo 已有的密钥密钥别名
  • --signing-keystore=uploadkey.keystore 上传到Google play的密钥
  • --signing-keystore=uploadkey.keystore 上传到Google play的密钥的别名

输入几次密码之后,会在本地生成output.zip,然后点击上传(Upload generated ZIP)就行可以了。

提交成功以后就可以在Google的签名里看到已经完成替换了。

赶紧发布新版本,经测试,成功!

总结

终于完美的解决了我们的问题,经过这一波操作,本地的签名和Google Play保持一致了。

最后,请关注我的公众号:OpenFlutter。感恩。

相关资料

Use Play App Signing

相关推荐
二闹1 分钟前
大厂前端研发岗位设计的30道Webpack面试题及解析
前端·面试
拾光拾趣录6 分钟前
实现 `this` 对象的深拷贝:从“循环引用崩溃”到生产级解决方案
前端·javascript
无羡仙8 分钟前
90%的人都在用的下拉刷新,我把它拆了!
前端·node.js
一念杂记8 分钟前
【实战系列】30分钟开发微信小程序登录&注册&绑定功能
前端·后端·微信小程序
阳焰觅鱼8 分钟前
LRU缓存
前端
福娃B10 分钟前
【CSS】面试必会—浮动布局:让元素“漂浮”的艺术
前端·css·面试
中微子12 分钟前
TypeScript 与 React:现代前端开发的黄金搭档
前端
用户25191624271112 分钟前
Canvas之颜色渐变
前端·javascript·canvas
ZzMemory13 分钟前
详解JavaScript 解构赋值:让你的代码更优雅
前端·javascript·面试
PineappleCoder15 分钟前
CSS那些你不得不懂的“潜规则”(二)
前端·css·面试