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
  • 전체
    오늘
    어제
    • 전체보기 (319)
      • 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(개발아님) (46)
        • Windows (26)
        • MacOS (7)
        • Utility (11)
      • 챗봇 짬통 (0)
      • 일상 (2)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바