前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >vue3+vite+axios中proxy跨域配置

vue3+vite+axios中proxy跨域配置

作者头像
kif
发布2023-02-27 17:47:09
发布2023-02-27 17:47:09
4.6K00
代码可运行
举报
文章被收录于专栏:kifroomkifroom
运行总次数:0
代码可运行

axios引入

安装:

代码语言:javascript
代码运行次数:0
复制
npm install axios -S    

src目录下创建api目录,下新建axios.js

axios.js

代码语言:javascript
代码运行次数:0
复制
import axios from 'axios'

// 创建一个 axios 实例
const service = axios.create({
	baseURL: '/api', // 所有的请求地址前缀部分
	timeout: 60000, // 请求超时时间毫秒
	withCredentials: true, // 异步请求携带cookie
	headers: {
		// 设置后端需要的传参类型
		'Content-Type': 'application/json',
		'token': 'your token',
		'X-Requested-With': 'XMLHttpRequest',
	},
})

// 添加请求拦截器
service.interceptors.request.use(
	function (config) {
		// 在发送请求之前做些什么
		return config
	},
	function (error) {
		// 对请求错误做些什么
		console.log(error)
		return Promise.reject(error)
	}
)

// 添加响应拦截器
service.interceptors.response.use(
	function (response) {
		// console.log(response)
		// 2xx 范围内的状态码都会触发该函数。
		// 对响应数据做点什么
		// dataAxios 是 axios 返回数据中的 data
		const dataAxios = response.data
		// 这个状态码是和后端约定的
		const code = dataAxios.reset
		return dataAxios
	},
	function (error) {
		// 超出 2xx 范围的状态码都会触发该函数。
		// 对响应错误做点什么
		console.log(error)
		return Promise.reject(error)
	}
)

export default service

调用:

代码语言:javascript
代码运行次数:0
复制
import service from '../axios'


export function getTest() {
    return service({
        url: '/pyq/index.php',//Api就是proxy中的target地址
        method: "get"
    })
}

export function apiGetUserInfo() {
    return service({
        method: 'get',
        url: '/api/topbaidu/index.php',//Api就是proxy中的target地址
    })
}
代码语言:javascript
代码运行次数:0
复制
<script setup>
import { onBeforeMount } from 'vue'

import { getTest, apiGetUserInfo } from '../api/demo/test'
onBeforeMount(() => {
    apiGetUserInfo().then(res => {
        console.log(res)
    })  // 这里的res是一个promise对象

})


</script>

代理设置

根目录下新建 vite.config.js

代码语言:javascript
代码运行次数:0
复制
module.exports = {
    proxy:{
        '/api':{
            target:' https://v.api.aa1.cn',
            changeOrigin:true,  // 允许跨域
            rewrite:path => path.replace(/^\/api/,'')
        }
    }
 
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022/06/26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • axios引入
    • 代理设置
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档