Nginx SPA에서 새로고침 시 404 Not Found 에러 발생

2021. 3. 9. 02:57·SW개발/Web
반응형

Nginx SPA에서 새로고침 시 404 Not Found 에러 발생

  • SPA(Single Page Application)

    • 새로운 페이지를 불러오지 않고, 현재 페이지를 동적으로 다시 작성하는 어플리케이션이나 웹 사이트

    • 내 경우엔 리액트로 빌드한 웹사이트였다. 원인이 리액트 소스코드에 있는 줄 알았는데 Nginx 문제였다.


원인

  • 하위주소에 대한 html 파일을 요청하는데, SPA의 경우 index.html 내부에서 처리하므로 이외의 파일을 찾을 수 없다.

해결

  • 파일을 찾아도 없으면 index.html 파일로 연결하도록 설정해야 한다.

  • nginx 설정 파일(/etc/nginx/conf.d/default.conf 혹은 /etc/nginx/sites-available/default)에서 try_files를 다음과 같이 설정한다.

    location / {
      try_files $uri $uri/ /index.html;
    }

참고

  • HotHandCoding
반응형
저작자표시 (새창열림)

'SW개발 > Web' 카테고리의 다른 글

Django 채팅 앱 만들기  (1) 2021.08.11
'SW개발/Web' 카테고리의 다른 글
  • Django 채팅 앱 만들기
Caniro
Caniro
  • Caniro
    Minimalism
    Caniro
  • 전체
    오늘
    어제
    • 전체보기 (320)
      • SW개발 (268)
        • Java Spring (6)
        • C++ (186)
        • Python (21)
        • Linux (16)
        • 알고리즘 (13)
        • Git (4)
        • Embedded (1)
        • Raspberrypi (9)
        • React (3)
        • Web (2)
        • Windows Device Driver (6)
      • IT(개발아님) (47)
        • Windows (26)
        • MacOS (8)
        • Utility (11)
      • 챗봇 짬통 (0)
      • 일상 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    윈도우 명령어
    dism
    unix
    spring
    KakaoTalk
    스프링 프레임워크 핵심 기술
    EXCLUDE
    제외
    그림판
    Workspace
    java
    SFC
    맥북 카카오톡 알림 안뜸
    logi options
    Windows 11
    MacOS
    로지텍 마우스 제스처
    Solaris 10
    백기선
    citrix workspace
    SunOS 5.1
    알림
    windows
    vscode
    윈도우
    시스템 복구
    mspaint
    스프링
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Caniro
Nginx SPA에서 새로고침 시 404 Not Found 에러 발생
상단으로

티스토리툴바