-
Notifications
You must be signed in to change notification settings - Fork 1
한국투자 Open API에서 access token을 발급받지 못하는 문제
JIN edited this page Dec 3, 2024
·
1 revision
⚙️ Web BE | ⚙️ Web BE |
---|---|
김진 | 이시은 |
한국투자 Open API에서는 API 요청을 할 때 access token을 필요로 해, access token을 발급받는 로직이 필요했다.
각각의 서비스에서 한국투자 Open API에 요청이 필요한 경우, access toekn 발급받는 로직을 작성해서 테스트를 진행했다.
이 과정에서 같은 app key/app secret 에 대해 access token을 발급받으려고 하니, 접근 토큰 신청 1분 제한이라는 에러가 발생하면서 access token을 발급받지 못하는 문제가 발생했다.
import axios from 'axios';
import { UnauthorizedException } from '@nestjs/common';
import { getFullURL } from '../../util/get-full-URL';
import { AccessTokenInterface } from './interface/korea-investment.interface';
import { getHeader } from '../../util/get-header';
export class KoreaInvestmentDomainService {
private accessToken: string;
private tokenExpireTime: Date;
async getAccessToken() {
// accessToken이 유효한 경우
if (this.accessToken && this.tokenExpireTime > new Date()) {
return this.accessToken;
}
const response = await axios
.post<AccessTokenInterface>(getFullURL('/oauth2/tokenP'), {
grant_type: 'client_credentials',
appkey: process.env.KOREA_INVESTMENT_APP_KEY,
appsecret: process.env.KOREA_INVESTMENT_APP_SECRET,
})
.catch(() => {
throw new UnauthorizedException('액세스 토큰을 조회하지 못했습니다.');
});
const { data } = response;
this.accessToken = data.access_token;
this.tokenExpireTime = new Date(data.access_token_token_expired);
return this.accessToken;
}
}
access token을 발급받는 로직을 하나로 합쳐 싱글톤으로 관리할 수 있게 변경했다.
싱글톤으로 관리하면, 각 서비스 로직에 해당하는 API를 호출할 때마다 access token을 발급받을 필요가 없고, 1분 제한이라는 에러가 발생하지 않아 좀 더 유연하게 사용할 수 있다.
- [FE] 프론트엔드 기술스택
- [FE] 라이브러리 없이 차트 구현 이유
- [FE] Canvas API 사용방법
- [FE] 네비게이션 바 애니메이션 구현
- [FE] Socket.io 사용방법
- [FE] Tanstack Router에 대하여...
- [FE] Intl(Internationalization) API
- [FE] React Suspense 적용
- [FE] 한글 입력 방식의 유연성을 높인 검색 시스템 구현하기
- [BE] 백엔드 기술 스택
- [BE] SSE vs Socket.io
- [BE] Redis를 도입하게 된 계기
- [BE] ACG Rule을 활용한 Secure CI CD 파이프라인 구현
- [BE] Nginx 로드밸런싱을 통해 한국 투자 API 소켓 제한 극복
- [BE] 주가 지수 기능 개발 과정
- [BE] 매수 및 매도 기능 개발 과정
- [BE] 실시간 자산 조회 기능 개발 과정
- [BE] 단위 테스트
- [BE] redis를 이용한 한국투자 Open API 세션 관리
- [BE] 데이터베이스 인덱싱
- [FE] React에서의 DOM 요소 접근 (useRef vs getElementById)
- [FE] Outlet을 활용한 공통 레이아웃 관리
- [FE] react hooks가 특정 조건에서 실행되면 안되는 이유 & useQuery에 query function 매개변수가 undefined일 수도 있을 때 어떻게 해결할까
- [FE] cross‐domain 로컬 환경에서 cookie로 인증 처리하기 with vite proxy
- [FE] 크롬&사파리 Composition 차이
- [FE] useEffect 의존성 배열
- [BE] Naver Cloud Platform HTTPS 무응답 현상
- [BE] 한국투자 Open API에서 access token을 발급받지 못하는 문제
- [BE] 한국투자 Open API와 웹소켓 연결이 되지 않던 문제
- [BE] 한국투자 Open API 웹소켓 연결이 중단되는 문제
- [BE] 같은 주식 주문이 동시에 여러 번 체결되는 문제
- [BE] 한국투자 Open API Websocket 세션을 두 개에서 한 개로 변경하기
- [BE] Nginx 로드 밸런싱 중 Socket bad Request 발생하는 현상
- [BE] 매수/매도 체결 로직에 의해 redis pub/sub이 정상적으로 동작하지 않는 문제