JooTC
next-js-logo-2020-blue

[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;
});

참고 자료

구독
알림
guest

0 Comments
Inline Feedbacks
모든 댓글 보기
0
이 포스트에 대한 의견을 남겨주세요!x