일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 프로그래머스 완전탐색
- websocket
- react hook
- 자바 공부
- vanillaJS
- 디자인 패턴
- React JS
- JavaScript
- react firebase
- 프로그래머스 자바
- 프로그래머스
- 코딩테스트 고득점 Kit 완전탐색
- design pattern
- useEffect
- 리액트
- useState
- NextJS
- 컴퓨터 네트워크
- Java
- react
- 프로그래밍 언어론
- 자바
- 리액트 훅
- 코틀린
- codesandbox
- 코딩테스트 고득점 Kit
- 데이터모델링과마이닝
- 장고
- 백준
- 자바스크립트
Archives
- Today
- Total
기록하는 개발자
[NextJs] next.config.js 의 redirects와 rewrites 본문
728x90
nextJs에서 자동으로 생성되는 파일 중 next.config.js 가 있다.
이 파일에서는 redirects와 rewrites 를 작성할 수 있다.
redirects
React에서 Router 작성 시 사용했던 Navigate 태그와 유사하다고 생각된다.
Source URL을 원하는 Destination URL로 간단하게 Redirect 할 수 있다.
const nextConfig = {
reactStrictMode: true,
async redirects() {
return [
{
// source로 이동하면 destination으로 가도록
source: "/about/*",
destination: "/",
permanent: false,
},
{
// token이 false일 때 "/"로 이동하면 "/login"으로 가도록
source: "/",
destination: "/login",
permanent: true,
has: [
{
type: "cookie",
key: "token",
value: "false",
},
],
},
];
},
};
module.exports = nextConfig;
rewrites
api path 및 api key를 은닉화 할 수 있는 기능이다.
redirects와 마찬가지로 source와 destination 을 필수 옵션으로 한다.
const API_KEY = process.env.API_KEY;
const nextConfig = {
reactStrictMode: true,
async redirects() { ... },
async rewrites() {
return [
{
source: "/api/dataList",
destination: `https://urlToGetData?api_key=${API_KEY}`,
},
// path parameter
{
source: "/api/dataWithId/:id",
destination: `https://urlToGetData/:id?api_key=${API_KEY}`,
},
// query string parameter
{
source: "/api/dataWithKeyword/:keyword",
destination: `https://urlToGetData/withKeyword?api_key=${API_KEY}&keyword=:keyword`,
},
];
},
};
module.exports = nextConfig;
호출 방법
- 별도의 import 없이 지정한 source로 api 를 요청할 수 있다.
const result = await (
await fetch(`http://localhost:3000/api/dataWithId/${id}`)
).json();
728x90
'Web > NextJs' 카테고리의 다른 글
[NextJs] NextJs에 TailwindCss 적용 하기 (1) | 2023.05.11 |
---|---|
[NextJs] NextJs에 Swiper 적용하기 (1) | 2023.05.11 |
[NextJs] getStaticProps와 getServerSideProps (0) | 2023.05.09 |
[NextJs] Routing과 navigation (0) | 2023.05.09 |
[NextJs] NextJs+Typescript로 프로젝트 시작하기 (0) | 2023.05.08 |