• vue项目跨域问题的解决:vue-cli 开启代理


    vue-cli 开启代理

    说明

    一般来说,当我们采取前后端分离的模式进行项目开发的话,那么前端和服务端的项目基本上可以说是两个项目了。

    在开发环境下,一般我们都会将vue项目运行在localhost:8080这个地址,而服务端项目,我们这里以express为例,默认情况下运行在localhost:3000这个地址,此时如果从vue项目访问服务端的项目就会发生跨域的问题。

    产生跨域的原因

    一般来说,跨域问题的产生是因为受到了同源策略的影响,那么什么是同源策略呢?

    mdn中给出的定义为:“ 同源策略是一个重要的安全策略,它用于限制一个origin的文档或者它加载的脚本如何能与另一个源的资源进行交互。它能帮助阻隔恶意文档,减少可能被攻击的媒介。”

    根据同源策略的规定,一般来说会把多个地址之间分为 同源非同源

    一个地址中,包括 协议域名端口 。而只有三者相同,才为同源。

    例如:

    URL 结果 原因
    http://store.company.com/dir2/other.html 同源 只有路径不同
    http://store.company.com/dir/inner/another.html 同源 只有路径不同
    https://store.company.com/secure.html 失败 协议不同
    http://store.company.com:81/dir/etc.html 失败 端口不同 ( http:// 默认端口是80)
    http://news.company.com/dir/other.html 失败 主机不同

    非同源状态会导致什么结果?

    如果两个端口之间处于非同源的状态,那么就会导致 CORS跨域 问题。

    类似如下的错误:

    cors跨域

    简单点说,当客户端请求了数据,服务端接收并且响应之后,浏览器就会检测是否处于同源状态,如果是非同源,就会把内容拦截住。

    vue cli 开启代理

    如果使用vue-cli创建项目,那么可以直接通过vue-cli中的proxy进行代理的设置。

    开启代理最简单的方式,可以在vue项目的根目录创建一个vue.config.js文件,然后设置如下的代码:

    module.exports = {
        devServer: {
            open: true,
            host: "127.0.0.1",
            port: "8080",
          // 代理
            proxy: {
                "/api": {
                    target: "http://127.0.0.1:3000",
                    changeOrigin: true,
                    pathRewrite: {
                        "^/api": ""
                    }
                }
    
    
            }
        }
    }
    

    在上面的代码中,proxy中相应的设置就是用来设置代理相关内容的代码。

    "/api"的设置,可以检测请求地址,如果以"/api"开头,就会默认使用下面的代理。"target"用来设置代理请求的地址, "changeOrigin"用来设置开启代理,"pathRewrite"用来将地址当中的"/api"替换为空。

  • 相关阅读:
    数据库的优化(非连接查询和连接查询的巧用)
    sql中为表添加一个含有括号的字段
    如何在有int型主键遍历表中的某一列数据
    三层架构的基本例子
    委托和事件
    sql中的常见函数
    博客园图灵杯第3届博问大赛(8.28~9.28)
    程序员部落酋长 Joel 之洞见
    安全领域多位世界级权威的智慧结晶——《黑客新型攻击防范:深入剖析犯罪软件》
    图灵“微软四大技术秘籍”近期出版!
  • 原文地址:https://www.cnblogs.com/liujunhang/p/12950309.html
Copyright © 2020-2023  润新知