Vue跨域详解

跨域,Vue · 浏览次数 : 39

小编点评

**问题分析** 页面无法访问API请求地址的问题,可能导致以下原因: 1. **请求头设置错误** 2. **本地运行要配置反向代理** 3. **环境配置问题** 4. **axios插件配置错误** 5. **网络错误** **解决方案** **1. 检查请求头设置** 在API请求中,确认请求头设置正确,其中`Content-Type`应设置为`application/json`。 **2. 配置本地反向代理** 如果使用的是Vue项目,需要配置本地反向代理才能访问远程 API。可以使用`proxy`选项在`proxyConfig`中配置代理地址和端口。 **3. 配置环境变量** 在`package.json`文件中设置环境变量`VUE_APP_BASE_URL`,并确保其正确配置。 **4. 验证axios插件配置** 确保`axios`插件已正确安装和配置。检查其配置文件中是否设置了正确的请求方法和参数。 **5. 检查网络错误** 仔细检查页面访问的网络请求,并检查服务器响应是否正常。可以使用网络调试工具来追踪请求过程。 **6. 验证代码逻辑** 检查`xxx`方法的代码逻辑,确保其正确处理请求参数并设置正确的请求方法。

正文

碰到这种问题,其实你的接口已经通了,但是在页面上就是访问不通过。

你可以把API请求地址单独拎出来新开个网站打开看请求是否成功,成功,但是你的项目不通。

有那么几个可能吧:

  1、请求头设置错误

headers = {
		'Content-Type': 'application/json' //错误的
          'Content-Type':'application/x-www-form-urlencoded' // 正确的 }

  2、本地运行要配置反向代理

最基础的配置

3、环境配置

当然你还需要配置你的环境配置文件(.env.dev   .env.production 等)

NODE_ENV='production' / 'development'   // 二选一,一个开发环境一个生产环境,部署服务器要用开发环境的
VUE_APP_RUN_ENV='dev'/'pro'/'test'  // 三选一可以自定义名字,按你定义的环境来定,自己分得清就行。只是一个标识
VUE_APP_BASE_URL = '' //这里是你请求后端的域名地址

假如你配置了多种环境那么你还需要配置下package.json文件

 --mode 后面是你配置的环境文件的 NODE_ENV 名字

 

 4、假如你用的是axios来作请求插件,那么还需要配置下axios

/****   request.js   ****/
// 导入axios
import axios from 'axios'
// 导入本地缓存
import {
    setStore,
    getStore
} from '../../util/lostore.js'
// 使用element-ui Message做消息提醒
import {
    Message
} from 'element-ui';
//1. 创建新的axios实例,
const service = axios.create({
    // 公共接口--这里注意后面会讲
    baseURL: process.env.VUE_APP_BASE_URL,
    // 超时时间 单位是ms,这里设置了5s的超时时间
    timeout: 5 * 1000
})
// 2.请求拦截器
service.interceptors.request.use(config => {
    //发请求前做的一些处理,数据转化,配置请求头,设置token,设置loading等,根据需求去添加
    config.data.__userToken = getStore('userToken')
    config.data = config.data; //数据转化,也可以使用qs转换
    config.headers = {
        'Content-Type': 'application/x-www-form-urlencoded'
    }
    return config
}, error => {
    Promise.reject(error)
})

// 3.响应拦截器
service.interceptors.response.use(response => {
    //接收到响应数据并成功后的一些共有的处理,关闭loading等
    return response.data
}, error => {
    /***** 接收到异常响应的处理开始 *****/
    if (error && error.response) {
        // 1.公共错误处理
        // 2.根据响应码具体处理
        // switch (error.response.status) {
        //     case 400:
        //         error.message = '错误请求'
        //         break;
        //     case 401:
        //         error.message = '未授权,请重新登录'
        //         break;
        //     case 403:
        //         error.message = '拒绝访问'
        //         break;
        //     case 404:
        //         error.message = '请求错误,未找到该资源'
        //         // window.location.href = "/NotFound"
        //         break;
        //     case 405:
        //         error.message = '请求方法未允许'
        //         break;
        //     case 408:
        //         error.message = '请求超时'
        //         break;
        //     case 500:
        //         error.message = '服务器端出错'
        //         break;
        //     case 501:
        //         error.message = '网络未实现'
        //         break;
        //     case 502:
        //         error.message = '网络错误'
        //         break;
        //     case 503:
        //         error.message = '服务不可用'
        //         break;
        //     case 504:
        //         error.message = '网络超时'
        //         break;
        //     case 505:
        //         error.message = 'http版本不支持该请求'
        //         break;
        //     default:
        //         error.message = `连接错误${error.response.status}`
        // }
    } else {
        // 超时处理
        if (JSON.stringify(error).includes('timeout')) {
            Message.error('服务器响应超时,请刷新当前页')
        }
        error.message = '连接服务器失败'
    }

    Message.error(error.message)
    /***** 处理结束 *****/
    //如果不需要错误处理,以上的处理过程都可省略
    return Promise.resolve(error.response)
})
//4.导入文件
export default service

封装统一的GET POST等常见的请求Function

/****   http.js   ****/
// 导入封装好的axios实例
import request from './request'

const http = {
    /**
     * methods: 请求
     * @param url 请求地址
     * @param params 请求参数
     */
    get(url, params) {
        const config = {
            method: 'get',
            url: url
        }
        if (params) config.params = params
        return request(config)
    },
    post(url, params) {
        const config = {
            method: 'post',
            url: url
        }
        if (params) config.data = params
        return request(config)
    },
    put(url, params) {
        const config = {
            method: 'put',
            url: url
        }
        if (params) config.params = params
        return request(config)
    },
    delete(url, params) {
        const config = {
            method: 'delete',
            url: url
        }
        if (params) config.params = params
        return request(config)
    }
}
//导出
export default http

再封装个api接口方法,妈呀停不下来了

// api.js
import request from "../common/axios/request.js"; // 例子 export function xxx(params) { return request({ url: "/login", method: "post", data: params }); } export function xxx(params) { return request({ url: "/login", method: "get", params: params }); }

ok,当你页面调用的时候就可以这样用:

首先引用你的接口api方法
import {
xxx
} from '../api/api.js'

然后在created或者mouted里就可以直接调用xxx方法啦
xxx(params).then(res => {
  console.log(res)
})

 

至此你可以试着去运行项目了

与Vue跨域详解相似的内容:

Vue跨域详解

碰到这种问题,其实你的接口已经通了,但是在页面上就是访问不通过。 你可以把API请求地址单独拎出来新开个网站打开看请求是否成功,成功,但是你的项目不通。 有那么几个可能吧: 1、请求头设置错误 headers = { 'Content-Type': 'application/json' //错误的

Vue微前端架构与Qiankun实践理论指南

这篇文章介绍了微前端架构概念,聚焦于如何在Vue.js项目中应用Qiankun框架实现模块化和组件化,以达到高效开发和维护的目的。讨论了Qiankun的原理、如何设置主应用与子应用的通信,以及如何解决跨域问题和优化集成过程,从而实现前端应用的灵活扩展与组织。

OpenTiny 跨端、跨框架组件库升级TypeScript,10万行代码重获新生

摘要:一份精心准备的《JS项目改造TS指南》文档供大家参考,顺便介绍TS 基础知识和 TS 在 Vue 中的实践。 本文分享自华为云社区《历史性的时刻!OpenTiny 跨端、跨框架组件库正式升级 TypeScript,10 万行代码重获新生!》,作者:Kagol。 根据 The Software

Iframe在Vue中的状态保持技术

Iframe是一个历史悠久的HTML元素,根据MDN WEB DOCS官方介绍,Iframe定义为HTML内联框架元素,表示嵌套的Browsing Context,它能够将另一个HTML页面嵌入到当前页面中。Iframe可以廉价实现跨应用级的页面共享,并且具有使用简单、高兼容性、内容隔离等优点,因此以Iframe为核心形成了前端平台架构领域第1代技术。

VUE系列之性能优化--懒加载

一、懒加载的基本概念 懒加载是一种按需加载技术,即在用户需要时才加载相应的资源,而不是在页面初始加载时一次性加载所有资源。这样可以减少页面初始加载的资源量,提高页面加载速度和用户体验。 二、Vue 中的懒加载 在 Vue.js 中,懒加载主要用于路由组件的按需加载。Vue Router 提供了非常便

深入理解 Vue 3 组件通信

在 Vue 3 中,组件通信是一个关键的概念,它允许我们在组件之间传递数据和事件。本文将介绍几种常见的 Vue 3 组件通信方法,包括 props、emits、provide 和 inject、事件总线以及 Vuex 状态管理。 1. 使用 props 和 emits 进行父子组件通信 props

Vue 3 后端错误消息处理范例

前端如何存储处理后端返回的错误信息,并按不同来源绑定到页面,例如显示在不同输入框的周围。这样即可实现清晰的错误显示。

Vue - 入门

零:前端目前形势 前端的发展史 HTML(5)、CSS(3)、JavaScript(ES5、ES6):编写一个个的页面 -> 给后端(PHP、Python、Go、Java) -> 后端嵌入模板语法 -> 后端渲染完数据 -> 返回数据给前端 -> 在浏览器中查看 Ajax的出现 -> 后台发送异步请

Vue 3深度探索:自定义渲染器与服务端渲染

这篇文章介绍了如何在Vue框架中实现自定义渲染器以增强组件功能,探讨了虚拟DOM的工作原理,以及如何通过SSR和服务端预取数据优化首屏加载速度。同时,讲解了同构应用的开发方式与状态管理技巧,助力构建高性能前端应用。

Vue第三方库与插件实战手册

这篇文章介绍了如何在Vue框架中实现数据的高效验证与处理,以及如何集成ECharts、D3.js、Chart.js等图表库优化数据可视化效果。同时,探讨了Progressive Web App(PWA)的接入与优化策略,以提升Web应用的用户体验与加载速度。