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 {

    //解决跨域
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")	// 允许跨域访问的路径
                .allowedOrigins("*")	// 允许跨域访问的源
                .allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE")	// 允许请求方法
                .maxAge(168000)	// 预检间隔时间
                .allowedHeaders("*")  // 允许头部设置
                .allowCredentials(true);	// 是否发送cookie
    }


    //资源处理器
    @Override
    public 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.data
        return 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,
    // 携带凭证  是否携带cookie
    withCredentials: true,
    // 返回数据类型
    responseType: 'json'
  }

相关推荐

  1. electron-vite如何解决问题

    2024-07-22 02:42:01       26 阅读
  2. Vue问题解决

    2024-07-22 02:42:01       46 阅读
  3. HBuilderX uniapp+vue3+vite axios封装

    2024-07-22 02:42:01       27 阅读
  4. 前端webpack、vite搭建项目如何解决

    2024-07-22 02:42:01       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-22 02:42:01       64 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-22 02:42:01       67 阅读
  3. 在Django里面运行非项目文件

    2024-07-22 02:42:01       54 阅读
  4. Python语言-面向对象

    2024-07-22 02:42:01       66 阅读

热门阅读

  1. Xcode代码静态分析:构建无缺陷代码的秘诀

    2024-07-22 02:42:01       21 阅读
  2. 半监督学习 原理与代码实例讲解

    2024-07-22 02:42:01       22 阅读
  3. 初学Mybatis之 CRUD 增删改查

    2024-07-22 02:42:01       17 阅读
  4. TensorFlow 的基本概念和使用场景

    2024-07-22 02:42:01       21 阅读
  5. Windows图形界面(GUI)-DLG-C/C++ - 列表视图(ListView)

    2024-07-22 02:42:01       22 阅读
  6. 大规模语言模型从理论到实践 高效模型微调

    2024-07-22 02:42:01       22 阅读
  7. [11 Qt CMake开发]

    2024-07-22 02:42:01       22 阅读
  8. 显示隐式-》初始化 & 类型转换

    2024-07-22 02:42:01       18 阅读
  9. ReentrantLock源码

    2024-07-22 02:42:01       21 阅读
  10. 向量数据库Milvus

    2024-07-22 02:42:01       24 阅读
  11. 在 ASP.NET Core Web API 中实现审计跟踪

    2024-07-22 02:42:01       19 阅读
  12. leetcode-56. 合并区间

    2024-07-22 02:42:01       20 阅读
  13. 后端开发: 如何去使用公共组件

    2024-07-22 02:42:01       18 阅读