48 lines
1.4 KiB
TypeScript
Executable File
48 lines
1.4 KiB
TypeScript
Executable File
import { useRouter } from "next/navigation";
|
||
|
||
// Token过期处理
|
||
export const handleTokenExpired = () => {
|
||
if (typeof window !== 'undefined') {
|
||
// 清除本地存储
|
||
localStorage.removeItem('token');
|
||
localStorage.removeItem('user');
|
||
|
||
// 使用客户端导航而不是直接修改window.location
|
||
// 避免在服务端渲染时执行
|
||
setTimeout(() => {
|
||
window.location.href = '/login';
|
||
}, 0);
|
||
}
|
||
};
|
||
|
||
// 响应拦截器
|
||
export const handleApiResponse = <T>(response: Response, result: any): T => {
|
||
// 处理token过期情况
|
||
if (result && (result.code === 401 || result.msg?.includes('token'))) {
|
||
// 仅在客户端处理token过期
|
||
if (typeof window !== 'undefined') {
|
||
handleTokenExpired();
|
||
}
|
||
throw new Error(result.msg || '登录已过期,请重新登录');
|
||
}
|
||
|
||
return result;
|
||
};
|
||
|
||
// 处理API错误
|
||
export const handleApiError = (error: unknown): never => {
|
||
console.error('API请求错误:', error);
|
||
|
||
if (error instanceof Error) {
|
||
// 如果是未授权错误,可能是token过期
|
||
if (error.message.includes('401') || error.message.includes('token') || error.message.includes('授权')) {
|
||
// 仅在客户端处理token过期
|
||
if (typeof window !== 'undefined') {
|
||
handleTokenExpired();
|
||
}
|
||
}
|
||
throw error;
|
||
}
|
||
|
||
throw new Error('未知错误,请稍后重试');
|
||
};
|