zoukankan      html  css  js  c++  java
  • Vue跨域实现原理(proxytable)

    1.1、使用proxyTable代理

    文件路径如下,在项目根目录下的config文件夹中的index.js中
    在这里插入图片描述

    配置代码如下

    dev{
    	proxyTable: {
          '/api': {
            target: 'http://192.168.0.1:200', // 要代理的域名
            changeOrigin: true,//允许跨域
            pathRewrite: {
              '^/api': '' // 这个是定义要访问的路径,名字随便写
            }
       }
    }

    使用时代码

     // /api/getMenu相当于*http://192.168.0.1:200/getMenu
     // /api相当于http://192.168.0.1:200
     this.$http.get("/api/getMenu", {
     }
     .then(res => {
     })
     .catch(function(error) {
     });

    1.2、注意事项

    以上面代码设置的为例,会把请求中所有带有/api字段的都替换掉,例如api/getMenu/api,前后两个都会被替换,导致404等错误,在代理数量比较多的时候容易出现这个问题。

    2、proxyTable原理

    浏览器是禁止跨域的,但是服务端不禁止,在本地运行npm run dev等命令时实际上是用node运行了一个服务器,因此proxyTable实际上是将请求发给自己的服务器,再由服务器转发给后台服务器,做了亦曾代理,因为不会出现跨域问题。

  • 相关阅读:
    random模块的随机变换
    re模块与正则表达式进阶
    面向对象整体细化
    __new__内部工作方式
    前端之CSS
    前端之HTML
    数据库
    同步异步阻塞非阻塞
    进程间的通信
    day 36(多进程)
  • 原文地址:https://www.cnblogs.com/Dylen24/p/13637487.html
Copyright © 2011-2022 走看看