티스토리 뷰
Nextjs 를 이용해서 api 통신을 할 때, 보안적인 문제 또는 외부에 있는 api 와 연결시에 주로 사용합니다.
참고로 Nextjs 에서는 pages/api 폴더 아래에 api 가 매핑되고 처리됩니다. 서버측 번들로만 구성되며, 클라이언트 측 번들 크기를 늘리지 않습니다.
API 경로 관리
절대 경로 사용: 서버 간 통신 시에는 절대 경로를 사용해야 합니다. 특히 외부 API를 호출하거나 내부 API 경로를 사용할 때, 상대 경로 대신 절대 경로를 사용해야 서버가 올바르게 요청을 처리할 수 있습니다.
서버에서 사용시에는 NEXT_PUBLIC_ 을 붙이지 않아도 됩니다.
const endpoint = `${process.env.BASE_URL}/api/some-endpoint`;
const handler = (req, res) => {
try {
const data = await get(endpoint)
res.status(200).json({ data })
} catch (err) {
res.status(500).json({ error: 'failed to load data' })
}
}
export default handler
환경 변수 활용: 배포 환경에 따라 URL이 다를 수 있기 때문에, Next.js에서 제공하는 .env 파일을 사용해 BASE_URL과 같은 환경 변수를 설정해 절대 경로를 관리하는 것이 좋습니다.
처리할 때 외부 API 호출은 절대경로, 내부는 상대경로로 해도 괜찮은 거를 인지하자!!
'개발.. > Nextjs' 카테고리의 다른 글
Nextjs14 에서 cors 해결방법 (0) | 2024.10.18 |
---|---|
Nextjs14 에서 서버, 클라이언트에서 URL 가져오는 방법 (0) | 2024.10.18 |
Nextjs14 app 기반 폴더/라우팅 구조 만들기 (0) | 2024.08.27 |
Nextjs14 에서 SEO 최적화 (robots.txt, sitemap.xml) (0) | 2024.04.11 |
Nextjs 14 에서 환경변수 설정하기 (0) | 2024.03.14 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- nuxt2
- NUXT
- NextJS
- dockerfile
- Vite
- Github Actions
- webpack
- nodejs
- vscode
- nextjs13
- cors
- 네이버 서치 어드바이저
- vue router
- svelte
- 타입스크립트
- Git
- docker
- 깃허브
- vue composition api
- 오블완
- 스벨트
- 서버 to 서버
- Storybook
- seo
- AWS
- nextjs14
- openAI
- Embedding
- React
- 티스토리챌린지
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
글 보관함