我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vueproxyTable的跨域中pathRewrite配置方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vueproxyTable的跨域中pathRewrite配置方式

vue浏览器跨域问题和vue proxyTable跨域中pathRewrite配置

vue浏览器跨域问题

当浏览器报如下错误时,则说明请求跨域了。

localhost/:1 Failed to load http://www.thenewstep.cn/test/testToken.php: Response to preflight request doesn’t pass access control check: No ‘Access-Control-Allow-Origin’ header is present on the requested resource. Origin ‘http://localhost:8080’ is therefore not allowed access. If an opaque response serves your needs, set the request’s mode to ‘no-cors’ to fetch the resource with CORS disabled.

为什么会跨域

因为浏览器同源策略的限制,不是同源的脚本不能操作其他源下面的对象。

什么是同源策略

同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。

可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。

简单的来说:协议、IP、端口三者都相同,则为同源

解决办法

跨域的解决办法有很多,比如script标签 、jsonp、后端设置cros等等…,但是我这里讲的是webpack配置vue 的 proxyTable解决跨域。

pathRewrite

简单来说,pathRewrite是使用proxy进行代理时,对请求路径进行重定向以匹配到正确的请求地址,

dev: {
    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
      '/api': {
        target: 'http://XX.XX.XX.XX:8083',
        changeOrigin: true,
        pathRewrite: {
          '^/api': '/api'   // 这种接口配置出来     http://XX.XX.XX.XX:8083/api/login
          //'^/api': '/' 这种接口配置出来     http://XX.XX.XX.XX:8083/login
        }
      }
    }
  },

如何不配置pathRewrite 请求就被转发到 http://XX.XX.XX.XX:8083 并把相应uri带上。

比如:localhost:8080/api/xxx 会被转发到http://XX.XX.XX.XX:8083/api/xxx

配置完成后需要重新编译一遍 , 调用接口的时候

        // 获取菜单权限
      getPermission(){
        this.$ajaxget({
          url: '/api/getPermission',
          data: {},
          isLayer: true,
          successFc: data => {
            console.log(data.data)
          }
        })

2种数据请求方式: fecth和axios

1、fetch方式

在需要请求的页面,只需要这样写(/apis+具体请求参数),如下:

fetch("/apis/test/testToken.php", {
      method: "POST",
      headers: {
        "Content-type": "application/json",
        token: "f4c902c9ae5a2a9d8f84868ad064e706"
      },
      body: JSON.stringify(data)
    })
      .then(res => res.json())
      .then(data => {
        console.log(data);
      });

2、axios方式

main.js代码

import Vue from 'vue'
import App from './App'
import axios from 'axios'
Vue.config.productionTip = false
Vue.prototype.$axios = axios //将axios挂载在Vue实例原型上
// 设置axios请求的token
axios.defaults.headers.common['token'] = 'f4c902c9ae5a2a9d8f84868ad064e706'
//设置请求头
axios.defaults.headers.post["Content-type"] = "application/json"

axios请求页面代码

this.$axios.post('/apis/test/testToken.php',data).then(res=>{
        console.log(res)
})

代理配置proxy下pathrewrite失效踩坑

从网上直接找到的代码复制过来报错,最后找了一下午为什么失效,最后发现问题直接破防了

错误:

pathRewrite: { 
  "  ^/api  "  : "" //若请求的路径在目标url下但不在/api 下,则将其转换成空
  },

正确:

pathRewrite: { 
  "^/api": "" //若请求的路径在目标url下但不在/api 下,则将其转换成空
   },

原因:

直接复制过来的 "  ^/api  "  : ""里面多了两个空格,判断url的时候就获取不到/api,删除空格就解决问题了

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vueproxyTable的跨域中pathRewrite配置方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue proxyTable的跨域中pathRewrite怎么配置

这篇文章主要介绍了vue proxyTable的跨域中pathRewrite怎么配置的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue proxyTable的跨域中pathRewrite怎么配置文章都会有所收
2023-06-29

SpringCloud gateway跨域配置的操作方式

这篇文章主要介绍“SpringCloud gateway跨域配置的操作方式”,在日常操作中,相信很多人在SpringCloud gateway跨域配置的操作方式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”S
2023-06-20

vue中vite.config.js配置跨域以及环境配置方式

这篇文章主要介绍了vue中vite.config.js配置跨域以及环境配置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-16

SpringCloud微服务中跨域配置的方法详解

在使用SpringCloud实现微服务时,经常会碰到前端页面访问多个二级域名的情况,跨域是首先要解决的问题。解决这个问题,可以从两方面入手,一种方案是在微服务各自的业务模块中实现,即在SpringBoot层实现,另外一种方案就是在Gateway层实现
2023-02-03

vue使用vite配置跨域及环境配置的方法

这篇文章主要介绍“vue使用vite配置跨域及环境配置的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue使用vite配置跨域及环境配置的方法”文章能帮助大家解决问题。如何配置跨域,代理域名不
2023-07-02

Vue3 跨域配置devServer的参数和设置方法

这篇文章主要介绍了Vue3 跨域配置devServer的参数和设置,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-17

Vue3跨域配置devServer参数的方法是什么

devServer是一个用于配置开发服务器的选项对象。它可以用来配置服务器的各种选项,例如代理,端口号,HTTPS等。以下是一些常用的devServer参数和设置:port:指定开发服务器的端口号,默认为8080。host:指定开发服务器的主机名,默认为localhost。https:开启HTTPS,可以传入一个Object类型的参数,用于配置HTTPS选项。open:自动打开浏览器,默认为false。可以传入一个String类型的参数,用于指定浏览器的名称。proxy:用于配置代理。可以传入一
2023-05-21

在SpringBoot 中实现跨域的方式有哪些

这篇文章给大家介绍在SpringBoot 中实现跨域的方式有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、为什么会出现跨域问题出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定,它
2023-06-06

Nginx配置WebSocket以支持跨域请求的解决方案

要在Nginx中配置WebSocket以支持跨域请求,你需要使用Nginx的http_sub_module模块首先,确保你已经安装了Nginx。如果没有,请访问Nginx官方网站下载并安装。打开Nginx配置文件,通常位于/etc/ngin
Nginx配置WebSocket以支持跨域请求的解决方案
2024-10-20

编程热搜

目录