救救我的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

相关推荐
@大迁世界5 分钟前
07.React 中的 createRoot 方法是什么?它具体如何运作?
前端·javascript·react.js·前端框架·ecmascript
January120714 分钟前
VBen Admin Select 选择框选中后仍然显示校验错误提示的解决方案
前端·vben
. . . . .21 分钟前
前端测试框架:Vitest
前端
xiaotao13132 分钟前
什么是 Tailwind CSS
前端·css·css3
战南诚2 小时前
VUE中,keep-alive组件与钩子函数的生命周期
前端·vue.js
发现一只大呆瓜2 小时前
React-彻底搞懂 Redux:从单向数据流到 useReducer 的终极抉择
前端·react.js·面试
霍理迪2 小时前
Vue的响应式和生命周期
前端·javascript·vue.js
李剑一2 小时前
别再瞎写了!Cesium 模型 360° 环绕,4 套源码全公开,项目直接用
前端
小码哥_常2 小时前
Android消息机制:Handler、Looper和Message的深度剖析
前端