chrome 升级 117后可能会导致你的网站无法访问

事情是这样的,团队的某个内网后台系统突然有一些页面报错无法访问,第一反应肯定是 F12,看看为啥不能访问,打开一看确实报错了,有3个文件请求失败,报 ERR_SSL_PROTOCOL_ERROR 错误,一般这个错误就是证书问题,检查证书之后发现证书没啥问题,也没有过期,然后赶紧问问其他同学是否能访问,一通操作之后最终定位出了可复现路径:

chrome桌面端 117 版本可复现,其他浏览器如火狐,safari 均可正常访问

于是开始谷歌、百度+AI一通搜,大概回答都是

  • 系统时间不正确
  • 浏览器缓存问题
  • 防火墙或防病毒软件
  • 证书无效
  • 禁用QUIC协议
  • 清除SSL状态
  • 不匹配的tls协议版本

万变不离其宗,有的看着就不靠谱,结果肯定是都不能解决我们本次遇到的问题。

那么还是从版本入手,既然是chrome的某个版本才出现的问题,肯定是这个版本更新了一些相关功能导致的,于是开始搜寻 chrome 版本更新日志。

找到最终更新日志的过程其实也不是那么容易,这里简单跟大家描述一下最后找到所用的路径:

这个就是最终的 chrome 每个版本的详细更新内容了!喜大普奔!

接下来看看日志里怎么说

打开网站,我们选择 117 版本,然后可以看到有很多更新项,等等,好像有个可疑的改动 Deprecate TLS SHA-1 server signatures

因为我们一开始就怀疑是证书相关的问题,那么这一项大概差不离就是我们要找的了。

这条更新的提供的关键信息就是:

  • Chrome 将删除对在 TLS 握手期间使用 SHA-1 进行服务器签名的签名算法的支持
  • SHA-1 可以通过临时 InsecureHashesInTLSHandshakesEnabled 企业策略暂时重新启用
  • 但是此策略将在 Chrome 123 中移除

赶紧去看一下我们网址的证书

查看证书可以点击网址上的小锁头或者 F12

破案啦!根证书签名算法用的 SHA-1,由于chrome在这个版本起不再支持该签名算法,所以使用该证书的网址在chrome 117 上都报错了。

先不着急同步到大群里,因为谷歌给了临时策略,先来试一下,我们访问 chrome://flags,搜索handshakes 或者 TLS,可以看到 Allow SHA-1 server signatures in *TLS*.这条配置,改为允许,然后重启

Chrome Flag 是实验性功能,其中大部分的 Flag 都是默认被禁用的。要启用这些功能,需要访问 chrome://flags

重启之后再重新打开网页就可以访问了。

但是这个只是一个临时策略,看官方意思是到 123 版本后会把这个策略给移除,所以这个方法治标不治本,而且也确实不安全,所以最好的做法还是通知运维同学升级证书。

总结

至此,该问题我们就顺利解决啦,把相关结论和解决方案同步到大群里后,收获了一波点赞,这里也分享给大家,避免浪费时间再去踩同样的坑。

后续我会持续关注 chrome 的更新动态,有较大影响和变动的也会第一时间在这里和大家分享,可以关注一波啦~

相关推荐
小白_ysf4 分钟前
Vue 中常见的加密方法(对称、非对称、杂凑算法)
前端·vue.js·算法
2501_944448001 小时前
Flutter for OpenHarmony衣橱管家App实战:支持我们功能实现
android·javascript·flutter
人工智能训练6 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪7 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
xiaoqi9228 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233228 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头882110 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas13610 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠10 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
2601_9498333910 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter