Ant Design Pro 使用proxy无法设置cookies

Ant Design Pro 使用proxy无法设置cookies

近期使用ant design Pro 实现了一个内部的后台。用于提供一个简单界面访问一些用户和设备的数据。
但近期需要将系统交接给其他同事继续开发。想要在本地配置proxy连接后端服务器。

1 关于AntD Pro配置代理

1.1 关于为什么要配置代理

AntD Pro 是前后端分离的前端框架,在部署时,一般会将前端代码打包和后端代码部署同一个域名下,所以不会有跨域的场景。比如使用nginx 部署·

  location / {
        try_files $uri $uri/ /index.html;

  }
  location /api {
      proxy_pass https://ant-design-pro.netlify.com;
      proxy_set_header   X-Forwarded-Proto $scheme;
      proxy_set_header   Host              $http_host;
      proxy_set_header   X-Real-IP         $remote_addr;
  }

但开发阶段,AntD Pro也会监听自己的端口,和后端服务器使用不同的端口,界面访问后端接口,这就出触发跨域,导致被浏览器拦截。

什么是同源策略?
同源策略限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的重要安全机制。

什么是跨域?
当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域
跨域问题的具体体现在浏览器上开发页面时,跨域的请求会被浏览器拦截。 请求url的协议、域名、端口一致则认为是同源。

所以为了方便开发,现在市面上所有的脚手架都提供了 proxy 的能力,底层基于 http-proxy-middleware, 这个包可以把所有符合正则匹配的请求转发到某个地址。这样就可以方便地进行开发。绕开同源策略带来与后端服务器交互问题。
其实也可以配置特殊Http Headers启用 CORS 来允许跨域来解决这个问题。
**
参考链接:https://pro.ant.design/blog/proxy-cn

1.2 如何配置代理

AntD Pro V4 是在config/proxy.js中配置代理。

// config/config.ts
export default {
  proxy: {
    '/api': {
      'target': 'http://jsonplaceholder.typicode.com/',
      'changeOrigin': true,
      'pathRewrite': { '^/api' : '' },
    },
  },
}

注意 proxy 配置不会改变你本地请求的 url(依旧是 http://localhost:8000/api/xxx),但是会在本地服务转发到 target 上。
target: 要与url模块解析的url字符串
changeOrigin: true, //true为开启跨域代理
pathRewrite,用'^/api':'', 把’/api’去掉。

比如后端接口为 http://jsonplaceholder.typicode.com/users
而前端为匹配 http://localhost:8000/api/users。 则可以将这个访问后端多出/api去掉。

详细的配置建议直接查看 webpack-dev 的配置。

2 无法设置cookie

在配置代理后访问后端服务器时,发现无法设置cookies。导致登录后不能跳转界面
但实际上,登录接口response 也返回了set-cookie 字段。那目前问题就是浏览器没有将set-cookies中的内容设置到aplication中。
在这里插入图片描述

这里发现有一个警告
在这里插入图片描述

问题就在这里了。因为后端服务器使用了https。而前端访问代理使用的是http。而后端返回的set-cookies 中的存在secure字段。所以导致浏览器处理cookies时发现Secure字段且当前地址为http,所以导致无法将存入到application中。
关于set-cookies中字段的内容 我们可以参考 MDN的说明
如果其中保留字段中的部分值与当前浏览器环境不一致则无法设置。

Secure:Cookie仅在使用该https:方案发出请求时才发送到服务器(本地主机除外**)不安全的网站(http:)无法使用Secure`属性设置Cookie 。

Path:请求的URL中必须存在一个路径,否则浏览器将不会发送Cookie标头。
Domain:如果省略,则默认为当前文档URL的主机,不包括子域。

如何解决?
使用 webpack-dev 的配置。使用onProxyRes 将Secure 字段拿掉。 当然这是你本地代理的情况下

  onProxyRes: function (proxyRes) {
        const cookies = proxyRes.headers['set-cookie'];
        let newCookie;
        if (cookies) {
          const cookiePathRegex = /secure;/;
          newCookie = cookies.map((cookie) => {
            if (cookiePathRegex.test(cookie)) {
              // 替换
              return cookie.replace(cookiePathRegex, '');
            }
            return cookie;
          });
          delete proxyRes.headers['set-cookie'];
          proxyRes.headers['set-cookie'] = newCookie;
        }
      },

3 参考连接

https://www.yuque.com/mdtvv0/myv5bw/es2oeo

### 回答1: 使用yarn初始化Ant Design Pro时出现错误可能有多种原因,下面给出几种常见的解决方法: 1. 确保安装了最新版本的Node.js和Yarn:首先检查已经安装了最新版本的Node.js和Yarn,可以通过在终端运行`node -v`和`yarn -v`来确认版本。如果版本过低,可以升级到最新版本。 2. 清除Yarn缓存:在终端中运行`yarn cache clean`命令来清除Yarn的缓存,然后重新运行`yarn`命令来初始化Ant Design Pro。 3. 检查网络连接:确保网络连接稳定,如果遇到网络问题可能会导致无法正常下载依赖包。可以先尝试使用`yarn config get proxy`命令来检查是否设置代理,如果设置代理可能需要将其关闭或者配置正确。 4. 检查依赖包版本:在初始化Ant Design Pro时,可能会遇到依赖包版本不兼容的问题。可以尝试更新依赖包或者在初始化时添加`--ignore-engines`参数来忽略引擎检查。 需要注意的是,以上解决方法只是针对一般情况的建议,具体情况可能因个人电脑环境和网络环境等因素而异。 ### 回答2: 使用yarn初始化ant design pro时报错可能是因为以下几个原因: 1. 网络问题:请确保您的网络连接正常,因为yarn初始化依赖于网络下载文件。 2. yarn版本问题:请确保您安装的yarn版本符合ant design pro的要求。您可以尝试升级或降级yarn版本,或者使用其他包管理工具,如npm。 3. 缓存问题:有时候yarn会使用缓存文件来安装依赖项。您可以尝试清除yarn的缓存并重新运行初始化命令,例如运行`yarn cache clean`命令。 4. 项目路径问题:请确保您在正确的项目文件夹路径下进行初始化操作,并且该文件夹没有其他冲突的文件或文件夹。 5. 其他依赖项冲突:有可能是因为其他依赖项的版本冲突导致报错。您可以尝试手动安装依赖项,或者通过更改项目的依赖项版本来解决冲突。 如果以上方法都不起作用,建议您查看报错信息的详细内容,根据报错信息来进一步排查问题并解决。您还可以尝试在开发者社区或相关论坛上寻求帮助,让更多有经验的开发者帮助您解决问题。 ### 回答3: 使用yarn初始化Ant Design Pro时,如果出现报错,可以尝试以下解决方法: 1. 确保已经安装了Node.js和Yarn,可以通过在命令行中运行`node -v`和`yarn -v`来检查版本。如果未安装,请下载并安装最新版本。 2. 检查网络连接,确保能够正常访问互联网。有时,下载依赖包需要从远程仓库获取,如果网络不稳定,可能会导致报错。 3. 尝试清除Yarn的缓存,有时缓存的内容可能会导致问题。可以在命令行中运行`yarn cache clean`来清除缓存。 4. 如果报错信息中有具体的错误提示,可以根据提示信息进行排查。有时可能是由于依赖版本不兼容或者缺少某些依赖导致的。 5. 可以尝试使用npm来初始化Ant Design Pro,有时使用不同的包管理工具可能会有不同的结果。 如果以上方法都不能解决问题,可以尝试在Ant Design Pro的GitHub页面上查找是否有类似的问题或者提问。在那里,可以找到开发者社区并与其他开发者讨论问题,或者提交一个新的issue以获得更多帮助。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值