Project.Fengling.QoderVersion/Frontend/Fengling.Backend.Admin/src/api/client.ts
sam 056eb9b6f9 feat: 实现完整的前后端功能
- 后端新增管理员、商品、分类聚合模型
- 实现积分规则、礼品、订单、会员等完整功能
- 添加管理员认证和权限管理
- 完善数据库迁移和实体配置
- 前端管理后台实现登录、仪表盘、积分规则、礼品、订单、会员等页面
- 集成shadcn-vue UI组件库
- 添加前后端功能文档和截图
2026-02-11 21:36:37 +08:00

43 lines
1.1 KiB
TypeScript

import axios from 'axios'
import type { ResponseData } from '@/types/api'
import { toast } from 'vue-sonner'
const apiClient = axios.create({
baseURL: import.meta.env.VITE_API_BASE_URL || '',
timeout: 15000,
headers: {
'Content-Type': 'application/json',
},
})
apiClient.interceptors.request.use((config) => {
const token = localStorage.getItem('admin_token')
if (token) {
config.headers.Authorization = `Bearer ${token}`
}
return config
})
apiClient.interceptors.response.use(
(response) => {
const data = response.data as ResponseData
if (data.success === false) {
toast.error(data.message || '操作失败')
return Promise.reject(new Error(data.message || '操作失败'))
}
return response
},
(error) => {
if (error.response?.status === 401) {
localStorage.removeItem('admin_token')
window.location.href = '/login'
return Promise.reject(error)
}
const message = error.response?.data?.message || error.message || '网络请求失败'
toast.error(message)
return Promise.reject(error)
},
)
export default apiClient