diff --git a/client/src/components/Headers/LoginHeader.tsx b/client/src/components/Headers/LoginHeader.tsx index 39cf20f..259f841 100644 --- a/client/src/components/Headers/LoginHeader.tsx +++ b/client/src/components/Headers/LoginHeader.tsx @@ -47,10 +47,10 @@ const LoginHeader: React.FC = () => { // 로그아웃 클릭 처리 함수 const handleLogout = () => { dispatch(setLogoutState()); // 전역변수에서 로그아웃 상태로 설정 - sessionStorage.removeItem("accessToken"); // 엑세스 토큰 제거 - sessionStorage.removeItem("refreshToken"); // 리프레시 토큰 제거 - sessionStorage.removeItem("logoutAlarmTime01"); - sessionStorage.removeItem("logoutAlarmTime02"); + localStorage.removeItem("accessToken"); // 엑세스 토큰 제거 + localStorage.removeItem("refreshToken"); // 리프레시 토큰 제거 + localStorage.removeItem("logoutAlarmTime01"); + localStorage.removeItem("logoutAlarmTime02"); // 페이지를 새로고침합니다. window.location.reload(); diff --git a/client/src/components/Logins/EmailLogin.tsx b/client/src/components/Logins/EmailLogin.tsx index e47e8af..a62ac21 100644 --- a/client/src/components/Logins/EmailLogin.tsx +++ b/client/src/components/Logins/EmailLogin.tsx @@ -43,7 +43,6 @@ const EmailLoginModal: React.FC = ({ onClose, onSignup }) } }; - // 🔴 자동 로그아웃 관련 코드 -> 정리 필요 const handleLoginClick = async () => { try { const response = await axios.post("http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/members/login", { email, password }, { validateStatus: (status) => status >= 200 && status < 600 }); @@ -52,8 +51,8 @@ const EmailLoginModal: React.FC = ({ onClose, onSignup }) const accessToken = response.headers["authorization"]; const refreshToken = response.headers["refresh"]; - if (accessToken) sessionStorage.setItem("accessToken", accessToken); - if (refreshToken) sessionStorage.setItem("refreshToken", refreshToken); + if (accessToken) localStorage.setItem("accessToken", accessToken); + if (refreshToken) localStorage.setItem("refreshToken", refreshToken); dispatch(setLoginState()); setAutoLogoutAlarm(dispatch, "first", secondAlarmTime, lastAlarmTime); @@ -70,7 +69,6 @@ const EmailLoginModal: React.FC = ({ onClose, onSignup }) } } }; - // 🔴 자동 로그아웃 관련 코드 -> 정리 필요 return ( diff --git a/client/src/components/StockOrderSection/StockOrder.tsx b/client/src/components/StockOrderSection/StockOrder.tsx index 1f7411b..52f4044 100644 --- a/client/src/components/StockOrderSection/StockOrder.tsx +++ b/client/src/components/StockOrderSection/StockOrder.tsx @@ -86,16 +86,17 @@ const StockOrder = ({ corpName }: { corpName: string }) => { // 1) 주말, 공휴일 여부 체크 const today = new Date(); - const nonBusinessDay = isHoliday(today, { include: { saturday: true, sunday: true } }); // 토요일, 일요일, 공휴일 (임시 공휴일 포함) + const isBusinessDay = !isHoliday(today, { include: { saturday: true, sunday: true } }); // 토요일, 일요일, 공휴일 (임시 공휴일 포함) // 2) 개장시간 여부 체크 const currentHour = today.getHours(); const currentMinute = today.getMinutes(); const isBefore9AM = currentHour < 9; const isAfter330PM = currentHour > 15 || (currentHour === 15 && currentMinute >= 30); - const closingTime = isBefore9AM || isAfter330PM; + const marketCloseTime = isBefore9AM || isAfter330PM; - const orderFailureCase01 = nonBusinessDay || closingTime; + const orderFailureCase01 = false; + // const orderFailureCase01 = !isBusinessDay || marketCloseTime; const orderFailureCase02 = orderPrice === 0 || orderVolume === 0; return ( diff --git a/client/src/components/communityComponents/Comments.tsx b/client/src/components/communityComponents/Comments.tsx index 94dc959..d89e85b 100644 --- a/client/src/components/communityComponents/Comments.tsx +++ b/client/src/components/communityComponents/Comments.tsx @@ -29,7 +29,7 @@ const Comments = ({ boardId }: { boardId: number }) => { setCommentsValue(e.target.value); }; - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const handleClickSubmit = async () => { if (commentsValue) { diff --git a/client/src/components/communityComponents/index.tsx b/client/src/components/communityComponents/index.tsx index 29c414b..1f0f318 100644 --- a/client/src/components/communityComponents/index.tsx +++ b/client/src/components/communityComponents/index.tsx @@ -59,7 +59,7 @@ const TimeLineComponent = () => { }; // 서브밋 버튼 클릭 - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const handleClickSubmit = async () => { // 로그인 토큰 확인 if (!accessToken) { diff --git a/client/src/hooks/stars/useDeletestars.ts b/client/src/hooks/stars/useDeletestars.ts index 37d5818..7078365 100644 --- a/client/src/hooks/stars/useDeletestars.ts +++ b/client/src/hooks/stars/useDeletestars.ts @@ -2,7 +2,7 @@ import { useMutation } from 'react-query'; // DELETE 요청을 수행하는 함수 const deleteStarData = async (companyId: number) => { - const accessToken = sessionStorage.getItem('accessToken'); + const accessToken = localStorage.getItem('accessToken'); const response = await fetch(`http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/stars/?companyId=${companyId}`, { method: 'DELETE', headers: { diff --git a/client/src/hooks/stars/useGetstars.ts b/client/src/hooks/stars/useGetstars.ts index 121860f..a4186a3 100644 --- a/client/src/hooks/stars/useGetstars.ts +++ b/client/src/hooks/stars/useGetstars.ts @@ -37,7 +37,7 @@ type StarData = StarDataItem[]; // : Promise const fetchStarData = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); // 로그인 상태에만 관심목록 데이터 호출하도록 설정 if (accessToken !== null) { diff --git a/client/src/hooks/stars/usePoststars.ts b/client/src/hooks/stars/usePoststars.ts index e3dc67f..637e473 100644 --- a/client/src/hooks/stars/usePoststars.ts +++ b/client/src/hooks/stars/usePoststars.ts @@ -1,7 +1,7 @@ import { useMutation } from 'react-query'; const postStarData = async (companyId: number) => { - const accessToken = sessionStorage.getItem('accessToken'); + const accessToken = localStorage.getItem('accessToken'); const res = await fetch(`http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/stars/?companyId=${companyId}`, { method: 'POST', headers: { diff --git a/client/src/hooks/useCash.ts b/client/src/hooks/useCash.ts index 46f03ba..81f3cdb 100644 --- a/client/src/hooks/useCash.ts +++ b/client/src/hooks/useCash.ts @@ -8,7 +8,7 @@ import { RootState } from "../store/config"; const BASE_URL = "http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080"; const getAuthHeader = () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); return { Authorization: `${accessToken}`, }; diff --git a/client/src/hooks/useDeleteMembers.ts b/client/src/hooks/useDeleteMembers.ts index 6a34e1a..60d7db6 100644 --- a/client/src/hooks/useDeleteMembers.ts +++ b/client/src/hooks/useDeleteMembers.ts @@ -7,7 +7,7 @@ export function useDeleteMember() { const dispatch = useDispatch(); return useMutation(async () => { - const accessToken = sessionStorage.getItem('accessToken'); + const accessToken = localStorage.getItem('accessToken'); const response = await axios.delete(`http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/members`, { headers: { Authorization: `${accessToken}` @@ -30,7 +30,7 @@ export function useDeleteMember() { }, { onSuccess: () => { // 토큰 삭제 - sessionStorage.removeItem('accessToken'); + localStorage.removeItem('accessToken'); // 로그아웃 상태로 변경 dispatch(setLogoutState()); diff --git a/client/src/hooks/useDeleteStockOrder.ts b/client/src/hooks/useDeleteStockOrder.ts index f5d84d1..27abc0a 100644 --- a/client/src/hooks/useDeleteStockOrder.ts +++ b/client/src/hooks/useDeleteStockOrder.ts @@ -19,7 +19,7 @@ export default useDeleteStockOrder; const deleteStockOrder = async (orderId: number, cancleVolume: number) => { const url = `http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/stock/stockorders?stockOrderId=${orderId}&stockCount=${cancleVolume}`; - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { Authorization: `${accessToken}`, diff --git a/client/src/hooks/useGetCash.ts b/client/src/hooks/useGetCash.ts index 833381c..5af0ddb 100644 --- a/client/src/hooks/useGetCash.ts +++ b/client/src/hooks/useGetCash.ts @@ -18,7 +18,7 @@ const useGetCash = () => { export default useGetCash; const getCashData = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { Authorization: `${accessToken}`, diff --git a/client/src/hooks/useGetCashId.ts b/client/src/hooks/useGetCashId.ts index 5b9b089..29d4bb7 100644 --- a/client/src/hooks/useGetCashId.ts +++ b/client/src/hooks/useGetCashId.ts @@ -26,7 +26,7 @@ const useGetCashId = () => { export default useGetCashId; const getCashData = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { Authorization: `${accessToken}`, diff --git a/client/src/hooks/useGetHoldingStock.ts b/client/src/hooks/useGetHoldingStock.ts index 68a388e..d8b62b8 100644 --- a/client/src/hooks/useGetHoldingStock.ts +++ b/client/src/hooks/useGetHoldingStock.ts @@ -17,7 +17,7 @@ const useGetHoldingStock = () => { export default useGetHoldingStock; const getHoldingStock = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { Authorization: `${accessToken}`, diff --git a/client/src/hooks/useGetMemberId.ts b/client/src/hooks/useGetMemberId.ts index e18b790..69fcf63 100644 --- a/client/src/hooks/useGetMemberId.ts +++ b/client/src/hooks/useGetMemberId.ts @@ -19,7 +19,7 @@ const useGetMemberId = () => { export default useGetMemberId; const getMemberId = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { diff --git a/client/src/hooks/useGetMemberInfo.ts b/client/src/hooks/useGetMemberInfo.ts index 511bd51..af08e24 100644 --- a/client/src/hooks/useGetMemberInfo.ts +++ b/client/src/hooks/useGetMemberInfo.ts @@ -3,7 +3,7 @@ import axios from "axios"; export function useGetMemberInfo() { return useQuery(["member"], async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const response = await axios.get(`http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/members`, { headers: { diff --git a/client/src/hooks/useGetStockInfo.ts b/client/src/hooks/useGetStockInfo.ts index 6530051..df72266 100644 --- a/client/src/hooks/useGetStockInfo.ts +++ b/client/src/hooks/useGetStockInfo.ts @@ -23,9 +23,9 @@ const useGetStockInfo = (companyId: number) => { const currentMinute = today.getMinutes(); const isBefore9AM = currentHour < 9; const isAfter330PM = currentHour > 15 || (currentHour === 15 && currentMinute >= 30); - const marketOpenTime = !isBefore9AM || !isAfter330PM; + const marketCloseTime = isBefore9AM || isAfter330PM; - const dataRenewalTime = isBusinessDay || marketOpenTime; + const dataRenewalTime = isBusinessDay || !marketCloseTime; // 개장 시간 이내일 경우, 현재 시각이 30분, 정각이 아닌 경우 남은 시간 계산하여 checkTime 함수 다시 실행 useEffect(() => { diff --git a/client/src/hooks/useGetStockOrderRecord.ts b/client/src/hooks/useGetStockOrderRecord.ts index a8a263a..b396040 100644 --- a/client/src/hooks/useGetStockOrderRecord.ts +++ b/client/src/hooks/useGetStockOrderRecord.ts @@ -18,7 +18,7 @@ const useGetStockOrderRecord = () => { export default useGetStockOrderRecord; const getOrderRecord = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { Authorization: `${accessToken}`, diff --git a/client/src/hooks/useGetStockholds.ts b/client/src/hooks/useGetStockholds.ts index 58a4746..d0fba1e 100644 --- a/client/src/hooks/useGetStockholds.ts +++ b/client/src/hooks/useGetStockholds.ts @@ -10,7 +10,7 @@ const useGetStockHolds = () => { export default useGetStockHolds; const getStockHolds = async () => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const res = await axios.get("http://ec2-13-125-246-160.ap-northeast-2.compute.amazonaws.com:8080/stock/stockholds", { headers: { Authorization: accessToken, diff --git a/client/src/hooks/useTradeStock.ts b/client/src/hooks/useTradeStock.ts index 1c86113..715a8e3 100644 --- a/client/src/hooks/useTradeStock.ts +++ b/client/src/hooks/useTradeStock.ts @@ -27,7 +27,7 @@ const useTradeStock = () => { export default useTradeStock; const postOrderRequest = async (orderType: boolean, companyId: number, price: number, volume: number) => { - const accessToken = sessionStorage.getItem("accessToken"); + const accessToken = localStorage.getItem("accessToken"); const options = { headers: { diff --git a/client/src/page/MainPage.tsx b/client/src/page/MainPage.tsx index 8bdaf6f..0d0cffb 100644 --- a/client/src/page/MainPage.tsx +++ b/client/src/page/MainPage.tsx @@ -133,25 +133,32 @@ const MainPage = () => { }; useEffect(() => { - const acessToken = sessionStorage.getItem("accessToken"); + const acessToken = localStorage.getItem("accessToken"); if (acessToken !== null) { - dispatch(setLoginState()); - const currentTime = Date.now(); - - const autoLogoutSecondAlarm = sessionStorage.getItem("autoLogoutSecondAlarm"); - const autoLogoutLastAlarm = sessionStorage.getItem("autoLogoutLastAlarm"); + const autoLogoutSecondAlarm = localStorage.getItem("autoLogoutSecondAlarm"); + const autoLogoutLastAlarm = localStorage.getItem("autoLogoutLastAlarm"); if (autoLogoutSecondAlarm !== null) { - const timeGone = currentTime - parseInt(autoLogoutSecondAlarm); - const remainTime = secondAlarmTime - timeGone; - setAutoLogoutAlarm(dispatch, "second", remainTime, lastAlarmTime); + if (currentTime >= parseInt(autoLogoutSecondAlarm) + secondAlarmTime + lastAlarmTime) { + localStorage.removeItem("autoLogoutSecondAlarm"); + } else { + const timeGone = currentTime - parseInt(autoLogoutSecondAlarm); + const remainTime = secondAlarmTime - timeGone; + dispatch(setLoginState()); + setAutoLogoutAlarm(dispatch, "second", remainTime, lastAlarmTime); + } } if (autoLogoutLastAlarm !== null) { - const timeGone = currentTime - parseInt(autoLogoutLastAlarm); - const remainTime = lastAlarmTime - timeGone; - setAutoLogoutAlarm(dispatch, "last", remainTime); + if (currentTime >= parseInt(autoLogoutLastAlarm) + lastAlarmTime) { + localStorage.removeItem("autoLogoutLastAlarm"); + } else { + const timeGone = currentTime - parseInt(autoLogoutLastAlarm); + const remainTime = lastAlarmTime - timeGone; + dispatch(setLoginState()); + setAutoLogoutAlarm(dispatch, "last", remainTime); + } } } }, []); @@ -164,31 +171,41 @@ const MainPage = () => { const refreshToken = urlParams.get("refresh_token"); const currentTime = Date.now(); - const autoLogoutSecondAlarm = sessionStorage.getItem("autoLogoutSecondAlarm"); - const autoLogoutLastAlarm = sessionStorage.getItem("autoLogoutLastAlarm"); + const autoLogoutSecondAlarm = localStorage.getItem("autoLogoutSecondAlarm"); + const autoLogoutLastAlarm = localStorage.getItem("autoLogoutLastAlarm"); if (accessToken && refreshToken) { - sessionStorage.setItem("accessToken", `Bearer ${accessToken}`); - sessionStorage.setItem("refreshToken", refreshToken); - dispatch(setLoginState()); + localStorage.setItem("accessToken", `Bearer ${accessToken}`); + localStorage.setItem("refreshToken", refreshToken); urlParams.delete("access_token"); urlParams.delete("refresh_token"); window.history.replaceState({}, "", "?" + urlParams.toString()); if (autoLogoutSecondAlarm === null) { + dispatch(setLoginState()); // 로그인 처리 setAutoLogoutAlarm(dispatch, "first", secondAlarmTime, lastAlarmTime); } if (autoLogoutSecondAlarm !== null) { + if (currentTime >= parseInt(autoLogoutSecondAlarm) + secondAlarmTime + lastAlarmTime) { + localStorage.removeItem("autoLogoutSecondAlarm"); + } + const timeGone = currentTime - parseInt(autoLogoutSecondAlarm); const remainTime = secondAlarmTime - timeGone; + dispatch(setLoginState()); // 로그인 처리 setAutoLogoutAlarm(dispatch, "second", remainTime, lastAlarmTime); } if (autoLogoutLastAlarm !== null) { + if (currentTime >= parseInt(autoLogoutLastAlarm) + lastAlarmTime) { + localStorage.removeItem("autoLogoutLastAlarm"); + } + const timeGone = currentTime - parseInt(autoLogoutLastAlarm); const remainTime = lastAlarmTime - timeGone; + dispatch(setLoginState()); // 로그인 처리 setAutoLogoutAlarm(dispatch, "last", remainTime); } } diff --git a/client/src/utils/setAutoLogoutAlarm.ts b/client/src/utils/setAutoLogoutAlarm.ts index 513af88..8da5a1b 100644 --- a/client/src/utils/setAutoLogoutAlarm.ts +++ b/client/src/utils/setAutoLogoutAlarm.ts @@ -29,11 +29,11 @@ const setAutoLogoutAlarm = (dispatch: any, alarmNum: string, secondAlarmTime: nu // 2차 알림 셋팅 시간 기록 const autoLogoutSecondAlarm = Date.now(); - sessionStorage.setItem("autoLogoutSecondAlarm", `${autoLogoutSecondAlarm}`); + localStorage.setItem("autoLogoutSecondAlarm", `${autoLogoutSecondAlarm}`); setTimeout(() => { // 2차 알림 셋팅 시간 제거 - sessionStorage.removeItem("autoLogoutSecondAlarm"); + localStorage.removeItem("autoLogoutSecondAlarm"); toast.warning("1분 뒤 로그아웃 처리됩니다", { style: toastStyle, @@ -42,15 +42,15 @@ const setAutoLogoutAlarm = (dispatch: any, alarmNum: string, secondAlarmTime: nu // 3차 알림 셋팅 시간 기록 const autoLogoutLastAlarm = Date.now(); - sessionStorage.setItem("autoLogoutLastAlarm", `${autoLogoutLastAlarm}`); + localStorage.setItem("autoLogoutLastAlarm", `${autoLogoutLastAlarm}`); setTimeout(() => { // 3차 알림 셋팅 시간 제거 - sessionStorage.removeItem("autoLogoutLastAlarm"); + localStorage.removeItem("autoLogoutLastAlarm"); dispatch(setLogoutState()); - sessionStorage.removeItem("accessToken"); - sessionStorage.removeItem("refreshToken"); + localStorage.removeItem("accessToken"); + localStorage.removeItem("refreshToken"); toast.warning("로그아웃 처리되었습니다", { style: toastStyle, @@ -64,7 +64,7 @@ const setAutoLogoutAlarm = (dispatch: any, alarmNum: string, secondAlarmTime: nu if (alarmNum === alarmNumType.Second) { setTimeout(() => { // 2차 알림 셋팅 시간 제거 - sessionStorage.removeItem("autoLogoutSecondAlarm"); + localStorage.removeItem("autoLogoutSecondAlarm"); toast.warning("1분 뒤 로그아웃 처리됩니다", { style: toastStyle, @@ -73,15 +73,15 @@ const setAutoLogoutAlarm = (dispatch: any, alarmNum: string, secondAlarmTime: nu // 3차 알림 셋팅 시간 기록 const autoLogoutLastAlarm = Date.now(); - sessionStorage.setItem("autoLogoutLastAlarm", `${autoLogoutLastAlarm}`); + localStorage.setItem("autoLogoutLastAlarm", `${autoLogoutLastAlarm}`); setTimeout(() => { // 3차 알림 셋팅 시간 제거 - sessionStorage.removeItem("autoLogoutLastAlarm"); + localStorage.removeItem("autoLogoutLastAlarm"); dispatch(setLogoutState()); - sessionStorage.removeItem("accessToken"); - sessionStorage.removeItem("refreshToken"); + localStorage.removeItem("accessToken"); + localStorage.removeItem("refreshToken"); toast.warning("로그아웃 처리되었습니다", { style: toastStyle, @@ -97,11 +97,11 @@ const setAutoLogoutAlarm = (dispatch: any, alarmNum: string, secondAlarmTime: nu if (alarmNum === alarmNumType.Last) { setTimeout(() => { // 3차 알림 셋팅 시간 제거 - sessionStorage.removeItem("autoLogoutLastAlarm"); + localStorage.removeItem("autoLogoutLastAlarm"); dispatch(setLogoutState()); - sessionStorage.removeItem("accessToken"); - sessionStorage.removeItem("refreshToken"); + localStorage.removeItem("accessToken"); + localStorage.removeItem("refreshToken"); toast.warning("로그아웃 처리되었습니다", { style: toastStyle,