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

相关推荐
Hao_Harrision16 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨| ThreeDBackgroundBoxes(3D背景盒子组件)
前端·3d·typescript·react·tailwindcss·vite7
加个鸡腿儿16 小时前
经验分享2:SSR 项目中响应式组件的闪动陷阱与修复实践
前端·css·架构
心.c16 小时前
如何基于 RAG 技术,搭建一个专属的智能 Agent 平台
开发语言·前端·vue.js
智航GIS16 小时前
10.7 pyspider 库入门
开发语言·前端·python
华仔啊17 小时前
写 CSS 用 px?这 3 个单位能让页面自动适配屏幕
前端·css
静听松涛13317 小时前
提示词注入攻击的防御机制
前端·javascript·easyui
晚风予星17 小时前
简记 | 一个基于 AntD 的高效 useDrawer Hooks
前端·react.js·设计
栗子叶17 小时前
网页接收服务端消息的几种方式
前端·websocket·http·通信
菩提小狗17 小时前
Sqli-Labs Less-3 靶场完整解题流程解析-豆包生成
前端·css·less
澄江静如练_17 小时前
优惠券提示文案表单项(原生div写的)
前端·javascript·vue.js