feat(mini-program): 添加 request.js API 请求诊断日志
- 在 request() 函数中添加请求/响应/错误日志 - 输出完整 URL、状态码、错误信息 - 仅在 DEBUG=true 时打印
This commit is contained in:
@@ -23,9 +23,22 @@ const getHeaders = () => {
|
|||||||
* @returns {Promise} 请求 Promise
|
* @returns {Promise} 请求 Promise
|
||||||
*/
|
*/
|
||||||
const request = (options) => {
|
const request = (options) => {
|
||||||
|
const debug = getEnvValue('DEBUG')
|
||||||
|
const fullUrl = `${API_BASE_URL}${options.url}`
|
||||||
|
|
||||||
|
// 请求日志
|
||||||
|
if (debug) {
|
||||||
|
console.log('[API Request]', {
|
||||||
|
method: options.method || 'GET',
|
||||||
|
url: fullUrl,
|
||||||
|
path: options.url,
|
||||||
|
env: import.meta.env.VITE_APP_ENV
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
uni.request({
|
uni.request({
|
||||||
url: `${API_BASE_URL}${options.url}`,
|
url: fullUrl,
|
||||||
method: options.method || 'GET',
|
method: options.method || 'GET',
|
||||||
data: options.data,
|
data: options.data,
|
||||||
header: getHeaders(),
|
header: getHeaders(),
|
||||||
@@ -33,6 +46,16 @@ const request = (options) => {
|
|||||||
success: (res) => {
|
success: (res) => {
|
||||||
const { data, statusCode } = res
|
const { data, statusCode } = res
|
||||||
|
|
||||||
|
// 响应日志
|
||||||
|
if (debug) {
|
||||||
|
console.log('[API Response]', {
|
||||||
|
path: options.url,
|
||||||
|
status: statusCode,
|
||||||
|
code: data?.code,
|
||||||
|
success: data?.code === 200 || data?.code === 0
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// 处理 401 未授权
|
// 处理 401 未授权
|
||||||
if (statusCode === 401) {
|
if (statusCode === 401) {
|
||||||
uni.removeStorageSync('access_token')
|
uni.removeStorageSync('access_token')
|
||||||
@@ -42,7 +65,7 @@ const request = (options) => {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// 后端返回格式: { code, message, data }
|
// 后端返回格式:{ code, message, data }
|
||||||
if (data.code === 200 || data.code === 0) {
|
if (data.code === 200 || data.code === 0) {
|
||||||
resolve(data)
|
resolve(data)
|
||||||
} else {
|
} else {
|
||||||
@@ -50,6 +73,14 @@ const request = (options) => {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
fail: (err) => {
|
fail: (err) => {
|
||||||
|
// 错误日志
|
||||||
|
if (debug) {
|
||||||
|
console.error('[API Error]', {
|
||||||
|
path: options.url,
|
||||||
|
error: err.errMsg,
|
||||||
|
env: import.meta.env.VITE_APP_ENV
|
||||||
|
})
|
||||||
|
}
|
||||||
reject(new Error(err.errMsg || '网络错误'))
|
reject(new Error(err.errMsg || '网络错误'))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user