NodeJS

[Next.js] TypeError: Unexpected MODIFIER at 0, expected END

TypeError: Unexpected MODIFIER at 0, expected END

Next.js 프레임워크를 사용하여 개발 또는 프로덕션 서버를 시작할 때 다음과 같이 에러가 발생하며 진행되지 않는 경우가 있습니다.

TypeError: Unexpected MODIFIER at 0, expected END
     at mustConsume (C:\MyProject\client\node_modules\path-to-regexp\dist\index.js:113:15)
     at parse (C:\MyProject\client\node_modules\path-to-regexp\dist\index.js:172:9)
     at stringToRegexp (C:\MyProject\client\node_modules\path-to-regexp\dist\index.js:329:27)
     at pathToRegexp (C:\MyProject\client\node_modules\path-to-regexp\dist\index.js:403:12)
     at new Layer (C:\MyProject\client\node_modules\koa-router\lib\layer.js:43:17)
     at Router.register (C:\MyProject\client\node_modules\koa-router\lib\router.js:570:17)
     at Router.<computed> [as get] (C:\MyProject\client\node_modules\koa-router\lib\router.js:200:12)
     at C:\MyProject\client\client-server\index.js:73:14
     at async C:\MyProject\client\client-server\index.js:19:5

해결 방법

기존의 Next.js 버전이 9로 업그레이드 되면서 라우터 경로 규칙이 변경되었습니다.

기존에 사용되던 전체 경로 해석을 위한 문자가 * 이었다면 이를 (.*) 또는 :splat* 으로 변경해야 합니다.

예를 들어 다음과 같이 되어 있는 코드가 있다면,

router.get('*', async ctx => {
    await handler(ctx.req, ctx.res);
    ctx.respond = false;
});

변경 후에는 다음과 같이 되어야 합니다.

router.get('(.*)', async ctx => {
    await handler(ctx.req, ctx.res);
    ctx.respond = false;
});

참고 자료

JooTC

안녕하세요. 테크놀로지에 관심이 많은 블로거입니다.

Recent Posts

Zalgo 텍스트와 이를 방지하는 방법

인터넷 커뮤니티 사이트에서 게시글이나 댓글에 간혹 장난을 목적으로 작성된 특이한 글자를 볼 수 있습니다. 위…

4주 ago

리눅스 kill, killall 명령어 – 특정 프로세스 종료하기

리눅스 명령어 - kill, killall 리눅스 kill 명령어는 특정 프로세스를 종료해주는 명령어입니다. 백그라운드에서 실행되고 있는…

4주 ago

JavaScript typeof null이 ‘object’인 이유

JavaScript는 역사가 긴 스크립트 프로그래밍 언어입니다. 세월이 흐르면서 많은 자바스크립트 표준이 만들어졌고, 현재는 많은 문법적…

4주 ago

Mocha Error: Resolution method is overspecified. 해결 방법

NodeJS 테스트 프레임워크인 Mocha는 비동기 테스트를 지원합니다. 간혹 특정 테스트 스크립트를 작성하고 실행하면 아래와 같이…

4주 ago

윈도우 11 설치 시 Microsoft 계정 로그인 없이 로컬 계정 만들기

언제부턴가 윈도우 11을 처음 설치할 때 마이크로소프트(Microsoft) 계정 로그인을 강제로 요구하게 되었습니다. 물론 마이크로소프트 계정이…

6개월 ago

에어팟 프로 2 케이스 스피커 소리를 완전히 끄는 방법

애플 에어팟 프로 2 (AirPods Pro 2) 케이스에는 스피커가 내장되어 있습니다. 그런데 간혹 아무 것도…

9개월 ago