Files
photography/frontend/lib/api.ts
iriver 4ab2c167e5
Some checks failed
部署管理后台 / 🧪 测试和构建 (push) Successful in 1m52s
部署前端网站 / 🧪 测试和构建 (push) Successful in 3m41s
部署管理后台 / 🔒 安全扫描 (push) Has been cancelled
部署管理后台 / 🚀 部署到生产环境 (push) Has been cancelled
部署前端网站 / 🚀 部署到生产环境 (push) Successful in 3m35s
feat: 更新管理后台部署工作流,优化文件上传和部署步骤
- 移除了压缩构建产物的步骤,直接上传构建文件夹到临时目录。
- 更新了部署步骤,清空旧文件并移动新文件到生产目录,增强了部署的可靠性。
- 新增了部署结果验证步骤,确保文件正确部署。

此更改提升了管理后台的部署效率和可维护性。
2025-07-16 20:05:55 +08:00

52 lines
1.3 KiB
TypeScript

import axios from 'axios'
// 创建axios实例
const api = axios.create({
baseURL: process.env.NEXT_PUBLIC_API_URL || 'http://localhost:3001/api',
timeout: 10000,
headers: {
'Content-Type': 'application/json',
},
})
// 请求拦截器
api.interceptors.request.use(
(config) => {
// 可以在这里添加token等认证信息
// 检查是否在浏览器环境中
if (typeof window !== 'undefined') {
const token = localStorage.getItem('token')
if (token) {
config.headers.Authorization = `Bearer ${token}`
}
}
return config
},
(error) => {
return Promise.reject(error)
}
)
// 响应拦截器
api.interceptors.response.use(
(response) => {
// 处理后端API的响应格式: { code: number, message: string, data: any }
const { code, message, data } = response.data
if (code !== 200) {
return Promise.reject(new Error(message || '请求失败'))
}
return data // 返回data部分
},
(error) => {
if (error.response?.status === 401) {
// 处理未授权 - 仅在浏览器环境中执行
if (typeof window !== 'undefined') {
localStorage.removeItem('token')
window.location.href = '/login'
}
}
return Promise.reject(error)
}
)
export default api