实现登出

This commit is contained in:
2025-05-13 11:58:29 +08:00
parent 6990df3678
commit 1bc34688a1
3 changed files with 21 additions and 4 deletions

View File

@@ -27,10 +27,11 @@ import {
useSidebar, useSidebar,
} from "@/components/ui/sidebar" } from "@/components/ui/sidebar"
import useSWR from "swr" import useSWR from "swr"
import { UserApi } from "@/lib/api" import { authApi, UserApi } from "@/lib/api"
import { Skeleton } from "./ui/skeleton" import { Skeleton } from "./ui/skeleton"
import { toast } from "sonner" import { toast } from "sonner"
import { useRouter } from "next/navigation" import { useRouter } from "next/navigation"
import { ApiError } from "next/dist/server/api-utils"
export function NavUser({ }: {}) { export function NavUser({ }: {}) {
const { isMobile } = useSidebar(); const { isMobile } = useSidebar();
@@ -41,7 +42,7 @@ export function NavUser({ }: {}) {
() => UserApi.me(), () => UserApi.me(),
{ {
onError: (error) => { onError: (error) => {
if (`${error}`.includes('Unauthorized')) { if (error.statusCode === 401) {
localStorage.removeItem('token'); localStorage.removeItem('token');
toast.info('登录凭证已失效,请重新登录'); toast.info('登录凭证已失效,请重新登录');
router.replace('/console/login'); router.replace('/console/login');
@@ -50,6 +51,16 @@ export function NavUser({ }: {}) {
} }
); );
async function logout() {
try {
await authApi.logout();
localStorage.removeItem('token');
toast.success('登出成功');
router.replace('/console/login');
} catch (error) {
toast.error('登出失败,请稍后再试');
}
}
return ( return (
<SidebarMenu> <SidebarMenu>
@@ -124,7 +135,7 @@ export function NavUser({ }: {}) {
</DropdownMenuItem> </DropdownMenuItem>
<DropdownMenuSeparator /> <DropdownMenuSeparator />
<DropdownMenuItem> <DropdownMenuItem onClick={logout}>
<LogOut /> <LogOut />
</DropdownMenuItem> </DropdownMenuItem>

View File

@@ -1 +1,2 @@
export * from './login'; export * from './login';
export * from './logout';

View File

@@ -0,0 +1,5 @@
import fetcher from "../fetcher";
export async function logout() {
return fetcher('/api/auth/logout', { method: 'POST' });
}