Compare commits

..

3 Commits

Author SHA1 Message Date
cc e32f8bf324 feat: 封装js 2025-05-10 22:30:39 +08:00
cc cf4813f33f feat: 封装js 2025-05-10 22:29:53 +08:00
cc a171926318 feat: 封装js 2025-05-10 22:29:19 +08:00
2 changed files with 3 additions and 72 deletions

View File

@ -1,69 +0,0 @@
import type { RequestClientOptions } from '@vben/request';
import { useAppConfig } from '@vben/hooks';
import { defaultResponseInterceptor, RequestClient } from '@vben/request';
import { useTokenStore } from '#/store'; // cc:增加token存储
const { apiURL } = useAppConfig(import.meta.env, import.meta.env.PROD);
function createCDCMRequestClient(
baseURL: string,
options?: RequestClientOptions,
) {
const client = new RequestClient({
...options,
baseURL,
});
client.addResponseInterceptor(
defaultResponseInterceptor({
codeField: 'code',
dataField: 'data',
successCode: 0,
}),
);
// 响应拦截器:自动更新 token
client.addResponseInterceptor({
fulfilled: (response) => {
const token = response.headers?.token;
if (token) {
// 如果响应头中有新 token自动更新 store
useTokenStore().setToken(token);
}
return response;
},
rejected: (error) => {
// 统一错误处理(如 token 过期)
if (error.response?.status === 401) {
useTokenStore().deleteToken();
// 这里要跳登录页面
}
return Promise.reject(error);
},
});
// 请求拦截器:自动添加 token
client.addRequestInterceptor({
fulfilled: (config) => {
const token = useTokenStore().token;
if (token) {
// 添加 CDCM 自定义头部
config.headers.set('cdcm', token, true);
}
return config;
},
rejected: (error) => {
// 请求错误处理
return Promise.reject(error);
},
});
return client;
}
export const cdcmRequestClient = createCDCMRequestClient(apiURL);
export async function cdcmTemplateAPI(params: any) {
return cdcmRequestClient.post('/api/v1/cdcm', params);
}

View File

@ -1,14 +1,14 @@
<script setup lang="js">
import { cdcmTemplateAPI } from '#/cdcm/api/api.js';
import { templateQuerySupportType } from '#/cdcm/api/req_code';
import { TemplateQueryPage } from '#/cdcm/api/req_code';
const params = {
page_num: 1,
page_size: 10,
};
console.warn(
'cdcmTemplateAPI',
cdcmTemplateAPI(params, templateQuerySupportType),
TemplateQueryPage.desc,
cdcmTemplateAPI(params, TemplateQueryPage),
);
</script>