您的位置:首页 > 健康 > 美食 > Vue3基于vite脚手架---如何解决跨域问题(附带axios的进一步封装)

Vue3基于vite脚手架---如何解决跨域问题(附带axios的进一步封装)

2024/10/7 6:48:18 来源:https://blog.csdn.net/m0_67725787/article/details/140595060  浏览:    关键词:Vue3基于vite脚手架---如何解决跨域问题(附带axios的进一步封装)

 问题的发现

一. 配置vite的vite.config.js

1.首先找到该文件的位置(在最下面)

2.填入代码

2.1配置所有路径都可跨域访问

// vite.config.js  
import { defineConfig } from 'vite';  export default defineConfig({  server: {  proxy: {  // 匹配所有路径,但请注意,这可能会带来安全风险  // 并且会覆盖所有直接访问的静态资源,除非你有特别的规则来处理它们  '/': {  target: 'http://your-backend-server.com', // 你的后端服务器地址  changeOrigin: true,  rewrite: (path) => path.startsWith('/') ? path : `/${path}` // 根据需要调整重写规则  },  },  },  // 其他配置...  
});

2.2只是配置单一路径(只有开头为api才能进行跨域)

// vite.config.js  
import { defineConfig } from 'vite';  export default defineConfig({  // ... 其他配置  server: {  // 配置代理  proxy: {  // '/api' 是你希望代理的前缀,你可以根据实际需要修改它  '/api': {  // target 是你的后端 API 服务器的地址  target: 'http://your-backend-server.com',  // changeOrigin 设置为 true,表示在发送请求时会自动改变原始主机头为目标 URL  changeOrigin: true,  // rewrite 是一个函数,用于重写请求的 URL 路径  // 在这个例子中,我们移除了路径中的 '/api' 前缀  rewrite: (path) => path.replace(/^\/api/, ''),  // 你可以根据需要添加更多的配置选项,如 headers、cookieDomainRewrite 等  },  // 你可以添加更多的代理规则,每个规则都映射到一个不同的后端服务  },  },  // ... 其他配置  
});

二. 配置idea端(基于springboot'项目)

package com.fs.user.config;import com.fs.user.constant.SystemConstant;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;/*** @author suke* @version 1.0* @title MyWebmvcConfig* @description* @create 2024/7/6 16:08*/
@SpringBootConfiguration
public class MyWebmvcConfig implements WebMvcConfigurer {//解决跨域@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**")	// 允许跨域访问的路径.allowedOrigins("*")	// 允许跨域访问的源.allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE")	// 允许请求方法.maxAge(168000)	// 预检间隔时间.allowedHeaders("*")  // 允许头部设置.allowCredentials(true);	// 是否发送cookie}//资源处理器@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {//给文件系统某个目录绑定一个url,//如果不加file: 表示从项目中找   /img/1.jpg   --> file: D:/upload/user/1.jpg//file: 从服务器本地文件系统查找registry.addResourceHandler("/img/**").addResourceLocations("file:"+ SystemConstant.IMAGE_SAVE_PATH+"/");}
}

三.封装axios的工具

1.安装qs

axios安装

npm instal axios

# npm安装
npm install qs

2.在src目录下创建一个utils目录,用于存放一些工具的js文件, 在这个目录下我们创建一个request.js用于封装axios

import axios from 'axios'
import qs from 'qs'
/*** axios的传参方式:* 1.url 传参 一般用于Get和Delete 实现方式:config.params={JSON}* 2.body传参 实现方式:config.data = {JSON},且请求头为:headers: { 'Content-Type': 'application/json;charset=UTF-8' }* 3.表单传参 实现方式:config.data = qs.stringify({JSON}),且请求头为:且请求头为:headers: { 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8' }*/
// axios实例
const $http = axios.create({baseURL: '',timeout: 60000,headers: { 'Content-Type': 'application/json;charset=UTF-8' }
})// 请求拦截器
$http.interceptors.request.use((config) => {// 追加时间戳,防止GET请求缓存if (config.method?.toUpperCase() === 'GET') {config.params = { ...config.params, t: new Date().getTime() }}if (Object.values(config.headers).includes('application/x-www-form-urlencoded')) {config.data = qs.stringify(config.data)}return config},error => {return Promise.reject(error)}
)// 响应拦截器
$http.interceptors.response.use(response => {const res = response.datareturn res},error => {return Promise.reject(error)}
)// 导出 axios 实例
export default $http

3.在main.js中,把$http绑定到app对象上

// 导入封装好的axios并挂载到Vue全局属性上
import $http from './utils/request'
app.config.globalProperties.$http = $http

使用:

 methods: {sendAjax(){this.$http.get("https://autumnfish.cn/cloudsearch?keywords=" + this.query).then(function(response) {console.log(response)}, function(err) {});}},

4.axios的配置文件

//axios的配置文件
export default {method: 'get',// 基础url前缀baseUrl: 'http://localhost:8080',// 请求头信息headers: {//默认的请求context-type: application/json'Content-Type': 'application/json;charset=UTF-8'},// 参数data: {},// 设置超时时间timeout: 10000,// 携带凭证  是否携带cookiewithCredentials: true,// 返回数据类型responseType: 'json'}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com