fetch http请求被转成https?

博客探讨了fetch API请求http资源时被自动转换为https的问题,通过排除法确定并非fetch API被修改或浏览器bug导致,最终发现在HTML中特定的meta标签(Upgrade-Insecure-Requests)是问题源头。此首部指示浏览器优先选择加密响应,影响了fetch行为。同时,文章提到fetch API目前无法直接获取上传进度。
部署运行你感兴趣的模型镜像

fetch http请求被转成https,以及fetch问题相关记录

http自动被转成https

  • 请仔细看下图
    在这里插入图片描述
    我们可以很简单的发现,我用的是原生api,然后请求一个http协议的,为什么报错提示的却是GET https:// why?按理来说,这个报错应该为http:// xxxx

  • 基于上面的问题,我们可以推测,这个fetch和标准的fetch有差异。
    然后我们很显然会去思考这个差异是哪里的来的?我们可以做以下猜测

  1. 最容易改浏览器fetch api的方式就是window.fetch = xxx…,可能是做了类似操作引起了上面的问题。
  2. 浏览器出bug了
  3. 有其他东西影响了,原生的fetch api让他表现出差异

然后我们可以先开始验证前两条猜测的正确性

1.我们可以很简单发现第一条显然不成立

在这里插入图片描述
如果我们修改了原生fetch api,我们打印fetch的值得时候,就会显示我们修改之后的值。所以问题不是因为修改了fetch api 引起的。

  1. 第二条也很好验证,在这里就不验证了。这个可能性比较小

那么我们可以得到肯定有其他什么东西影响了fetch api

  1. 怀着疑惑,我们看了一眼html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  <meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">
  <meta name="theme-color" content="#000000">
  <title></title>
</head>

<body>
  <div id="root"></div>
</body>
</html>
  • 在一大段代码中发现了一个很特殊的meta标签
    <meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests"

我们可以尝试注释一下,发现原来的问题没有了,终于找到罪魁祸首了

然后我们就可以找到这是为什么了,具体原因是Upgrade-Insecure-Requests 是一个请求首部,用来向服务器端发送信号,表示客户端优先选择加密及带有身份验证的响应,并且它可以成功处理 upgrade-insecure-requests CSP 指令。

上传进度的获取

  • 你如果要用fetch实现上传进度,搜一下会发现目前没解决方案
    在这里插入图片描述

thanks

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值