Vue+axios如何解决跨域

1、为什么会产生跨域?

出于浏览器的同源策略限制。 同源策略(Sameoriginpolicy)是一种约定,是浏览器的一种安全机制,它阻止了不同域之间进行的数据交互,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。所谓同源(即指在同一个域)就是两个页面具有相同的协议(protocol),主机(host)和端口号(port)。

2、什么是跨域?

当后端接口的url和页面的url的端口,协议,域名有一个或多个不同时就会产生跨域。

3、如何解决跨域?

在vue.config.js文件中配置,有的则在config文件夹下的index.js文件中配置。

在配置完成后还是报错跨域,则重启编译器运行即可。

复制代码
proxy: {
  '/api': {
    target: 'http://192.168.1.36:8080',// 需要代理的后端接口
    changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求
    pathRewrite: {//重写匹配的字段,如果不需要在请求路径上,重写为""
      '/api': ''
    }
  }
}

Proxy也称为网络代理,什么是代理?通俗来说就是一个中间商。官方说就是一种特殊的网络服务,允许一个客户端通过这个服务与另一个网络终端(一般为服务器)进行非直接的连接,一些网关、路由器等网络设备就具有网络代理功能。一般认为代理服务有利于保障网络终端的隐私或安全,防止服务器被攻击。

4、axios封装

复制代码
// 创建axios实例
const service = axios.create({
  baseURL: "/api",
  // 请求超时的时间
  timeout: 10000,
});

5、创建请求

复制代码
export function getdeptinfo(){
    return request({
        url:"/queryAllDeptAndIntroduce",
        method:"GET",
    })
}
相关推荐
木卫二号Coding1 天前
Docker-构建自己的Web-Linux系统-Ubuntu:22.04
linux·前端·docker
daols881 天前
vue2 甘特图 vxe-gantt 一行渲染多个子任务的配置
vue.js·甘特图·vxe-table
CHU7290351 天前
一番赏盲盒抽卡机小程序:解锁惊喜体验与社交乐趣的多元功能设计
前端·小程序·php
RFCEO1 天前
前端编程 课程十二、:CSS 基础应用 Flex 布局
前端·css·flex 布局·css3原生自带的布局模块·flexible box·弹性盒布局·垂直居中困难
天若有情6731 天前
XiangJsonCraft v1.2.0重大更新解读:本地配置优先+全量容错,JSON解耦开发体验再升级
前端·javascript·npm·json·xiangjsoncraft
2501_944525541 天前
Flutter for OpenHarmony 个人理财管理App实战 - 预算详情页面
android·开发语言·前端·javascript·flutter·ecmascript
打小就很皮...1 天前
《在 React/Vue 项目中引入 Supademo 实现交互式新手指引》
前端·supademo·新手指引
C澒1 天前
系统初始化成功率下降排查实践
前端·安全·运维开发
摘星编程1 天前
React Native + OpenHarmony:自定义useFormik表单处理
javascript·react native·react.js
C澒1 天前
面单打印服务的监控检查事项
前端·后端·安全·运维开发·交通物流