1
0
forked from baron/baron-sso

로그인 invalid_request 오류 해결

This commit is contained in:
2026-03-18 12:31:25 +09:00
parent 9d888a1162
commit 1af3103cde
6 changed files with 7 additions and 4 deletions

View File

@@ -297,3 +297,4 @@ function AppLayout() {
} }
export default AppLayout; export default AppLayout;
// force reload

View File

@@ -17,7 +17,7 @@ export const router = createBrowserRouter(
element: <LoginPage />, element: <LoginPage />,
}, },
{ {
path: "/auth/callback", path: "/callback",
element: <AuthCallbackPage />, element: <AuthCallbackPage />,
}, },
{ {

View File

@@ -392,3 +392,4 @@ function AppLayout() {
} }
export default AppLayout; export default AppLayout;
// force reload

View File

@@ -11,6 +11,7 @@ export interface UserProfile {
email: string; email: string;
name: string; name: string;
role: string; role: string;
phone?: string;
companyCode?: string; companyCode?: string;
tenantId?: string; tenantId?: string;
tenant?: Tenant; tenant?: Tenant;

View File

@@ -29,7 +29,7 @@ apiClient.interceptors.response.use(
async (error) => { async (error) => {
if (error.response?.status === 401) { if (error.response?.status === 401) {
// 401 발생 시 로그인 페이지로 리다이렉트 // 401 발생 시 로그인 페이지로 리다이렉트
const isAuthPath = window.location.pathname.startsWith("/auth/callback"); const isAuthPath = window.location.pathname.startsWith("/callback");
const isLoginPath = window.location.pathname === "/login"; const isLoginPath = window.location.pathname === "/login";
const user = await userManager.getUser(); const user = await userManager.getUser();
// 인증 토큰이 없는 경우에만 로그인으로 보낸다. // 인증 토큰이 없는 경우에만 로그인으로 보낸다.

View File

@@ -5,11 +5,11 @@ export const oidcConfig: AuthProviderProps = {
authority: authority:
import.meta.env.VITE_OIDC_AUTHORITY || "http://localhost:5000/oidc", // Gateway Proxy URL import.meta.env.VITE_OIDC_AUTHORITY || "http://localhost:5000/oidc", // Gateway Proxy URL
client_id: import.meta.env.VITE_OIDC_CLIENT_ID || "devfront", client_id: import.meta.env.VITE_OIDC_CLIENT_ID || "devfront",
redirect_uri: `${window.location.origin}/auth/callback`, redirect_uri: `${window.location.origin}/callback`,
response_type: "code", response_type: "code",
scope: "openid offline_access profile email", // offline_access for refresh token scope: "openid offline_access profile email", // offline_access for refresh token
post_logout_redirect_uri: window.location.origin, post_logout_redirect_uri: window.location.origin,
popup_redirect_uri: `${window.location.origin}/auth/callback`, popup_redirect_uri: `${window.location.origin}/callback`,
userStore: new WebStorageStateStore({ store: window.localStorage }), userStore: new WebStorageStateStore({ store: window.localStorage }),
automaticSilentRenew: true, automaticSilentRenew: true,
}; };