浏览器使用小记 – Content-Security-Policy

博主在使用Kong作为API网关时遇到第三方系统响应中拼接HTTP URL导致浏览器因CSP(Content-Security-Policy)阻止的问题。讨论了解决方案,包括让第三方系统采用relative URL或通过设置Kong的响应头`content-security-policy: upgrade-insecure-requests`自动升级不安全请求为HTTPS。文章强调了减少系统耦合和网关透明性的原则,并对CSP和浏览器安全策略进行了简要说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

个人博客

最近重度使用网关 Kong,对接了一堆难搞的存量系统,遇到很多问题,先扔一个:当 Kong 转发请求后,第三方的响应内容里拼接了完整的资源请求地址,但它看到的只是 Kong 剥掉 https 壳以后的 http 请求,所以拼接出来的地址是 http://…. ,到了浏览器端,根据该地址发起 http 请求时,就会被浏览器 block 掉,开 debug 可以看到提示 csp 或者 mixed。

在有多个组成环节的情况下,一个问题通常就会有多种解法(甩锅应该更形象)。就目前这个问题,淡化 PaaS/CaaS 等设施的情况下,参与环节可以聚焦到三个:客户端浏览器 — Kong 网关 — 存量X系统。

最直接的想法就是由 X 系统自行调整,从尽量减少耦合的角度来说,一个系统应该尽量不了解其他系统的知识,不应该拼接完整的 url 请求地址,最好是能根据 rfc7231 里的描述改用 relative url absolute path,完整的请求地址则交由客户端浏览器去拼接。

然鹅存续时间比较长的企业里,历史积累下来的各种存量系统情况一般都比较复杂,存量 X 系统无力调整。秉着网关尽量透明的原则,分析处理之。

回到最开始浏览器提示的 CSP 问题,CSP 即 Content-Security-Policy,因为我们的网站在浏览器端是通过 https 访问的,从一个 https 的网页上发起 http 请求,属于安全性降级的操作,被认为是不安全的,所以浏览器直接 block 掉。

但是这种情形实际上并不少见,比如我的网站以前去第三方请求了一些资源,当时大家都是 http,没啥问题,后来我一夜之间升级到 https 后,因为浏览器安全策略可能就加载不到这些资源了。

这下咋办?标准里打了一个补丁,允许通过设置 upgrade-insecure-requests(字面意思:升级不安全的请求),告知浏览器自动将 http 的请求替换为 https 的请求。

按这个思路,在返回的第一个响应经过 Kong 时,设置上【content-security-policy: upgrade-iinsecure-requests】就可以了。

ps:csdn 啥时候又上了个尬到抠脚的发文助手,这么搞吃枣药丸

回答: 根据引用中提到的信息,requests库是一个用于进行HTTP通信的Python库,它可以直接与谷歌浏览器驱动进行通信,驱动Chrome浏览器执行命令。然而,requests库本身并不涉及浏览器版本的问题。所以,如果您目前使用浏览器版本过低,您可能需要升级浏览器版本,或者使用更新的谷歌浏览器驱动(chromedriver)来进行通信。请注意,具体的升级方法会根据您所使用浏览器和操作系统的不同而有所不同。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [selenium 原理应用 - 利用 requests 模拟 selenium 驱动浏览器](https://blog.youkuaiyun.com/weixin_45674354/article/details/123055618)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [浏览器使用小记Content-Security-Policy](https://blog.youkuaiyun.com/alading2009/article/details/123972903)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [requests模块的使用](https://blog.youkuaiyun.com/apollo_miracle/article/details/84769941)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值