• 목록
  • 아래로
  • 위로
  • 1
  • Ruwaku
  • 조회 수 313

React 배포 시 그냥 React build 후 웹호스팅에 올려도 정상 동작 합니다...

하지만 React의 경우 React-Router를 많이 사용합니다.

React-Router BrowserRouter의 URL은 가짜 주소라서 새로고침하면 404 오류를 뿜는다는거 알고 계실겁니다.

 


 

React-Router BrowserRouter가 적용된 앱을 배포하는 방법은

.htaccess 파일을 활용하는것 입니다.

 

사용자가 특정 디렉토리에 접근할 경우

해당 디렉토리에 .htaccess 파일이 있다면 그 파일을 읽어 시키는대로 합니다.

(루트 디렉토리에 올리면 모든 디렉토리에 적용이 되고, 원하는 디렉토리마다 각각 놓을 수도 있습니다)

 

원래는 apache나 nginx 설정을 통해 적용 가능하지만 우리는 그 곳에 접근할 수 없기에 htaccess를 활용합니다.

 

htaccess 옵션 중 우리가 살펴볼 옵션은

RewriteRule입니다.

<사용자가 입력한 URL을 해석하여 다른페이지로 보내는 등의 행동을 하는 옵션입니다>

 


 

이제 눈치가 빠르신 분들은 벌써 어떻게하는지 방법쯤은 감이 잡히시죠?

 

리액트 앱을 배포한 디렉토리에서 사용자가 입력한 URL의 파일이 존재하지 않는다면

index.html로 URL은 유지한 채 리다이렉트 하겠습니다

 

주의: 만약 사용자가 입력한 URL에 파일이 존재하는지 체크하지 않는다면

css, js 이런 파일들 마저 index.html로 리다이렉트 시키기 때문에 오류가 발생합니다.

 


 

#.htaccess의 주석!
# ▼ RewriteEngine을 활성화 합니다
RewriteEngine On
# ▼ 접속한 곳이 index.html이 아니라면
RewriteRule ^index\.html$ - [L]
# ▼ 그와 동시에 접속한 곳에 파일이 없다면
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-l
# ▼ URL은 유지한 채 index.html을 표시합니다
RewriteRule . ./index.html [L]

 

주석을 참고하시면 되겠습니다.

 

이렇게하면 /blabla 이런식으로 없는 파일명 URL로 접속해도

정상적으로 React Routing 가능합니다.

 

(404는 React에서 구현해야 함. 구글 검색 ㄱㄱ!!)

 

 

 

htaccess에 대한 자료가 너무 적은탓에 저처럼 삽질하시지 말고 도움 되시길 바랄게요

이니스프리님 이니스프리 포함 1명이 추천

추천인 1

댓글 1

joyfuI
리액트 공부하고 았는데 구글링하다가 스포어에 돌아왔네요ㅎㅎ
좋은 글 감사합니다.
comment menu
2021.03.30. 14:33

신고

"joyfuI님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 924
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4593
489 [파이썬] 텔레그램 봇으로 이미지 보내기 이니스프리 이니스프리 19.12.06.14:12 2139
488 [Python] Selenium에서 팝업을 허용하는 방법 이니스프리 이니스프리 18.11.01.21:37 2130
487 메일수신이 안된다고...? mail.yandex.com mx 리코드를 이용해보자 2 image djdisodo 18.02.21.17:04 2128
486 xss 공격 방어 라이브러리 jin**** jin**** 17.07.18.20:30 2094
485 [Python] HWP 파일 읽기 6 이니스프리 이니스프리 20.10.18.12:19 2091
484 [Python] BeautifulSoup에서 class명에 공백이 있을 때 검색 방법 이니스프리 이니스프리 21.02.13.00:26 2044
483 ABBYY FineReader의 OCR 언어 세팅 - 한국어(한글) vs 한국어 등 관련 이니스프리 이니스프리 18.11.05.16:07 2032
482 [Python] 현재시각에 따라 오전/오후 반환 이니스프리 이니스프리 20.07.16.13:58 2019
481 단위 명사의 띄어쓰기 (한컴워드의 맞춤법 검사를 믿지 마세요) 8 이니스프리 이니스프리 20.03.23.20:02 1985
480 윈도우 탐색기의 새로 고침 기능 자동화하기 2 이니스프리 이니스프리 18.11.13.13:59 1973
479 .tk(freenom) 로 접속이 안되는 분들이 요즘 왕왕보이네요. 15 image 마스터 마스터 16.10.05.13:40 1937
478 Youtube-DLG에서 10014 소켓 에러가 뜨는 경우 해결 방법 (방화벽 관련) 2 image 이니스프리 이니스프리 18.10.16.06:44 1881
477 그누보드에서 우측 aside(로그인) 없애고 회원가입을 봉쇄하는 방법 1 이니스프리 이니스프리 18.10.06.17:34 1836
476 [Python] 디렉토리 내의 파일명을 시간순으로 정렬하기 이니스프리 이니스프리 20.07.13.15:57 1835
475 [정리] 그누보드 관련된 몇 가지 소식들 이니스프리 이니스프리 18.12.29.15:32 1828
474 나라배움터 에러 발생 대처방법 이니스프리 이니스프리 20.05.01.20:59 1817
473 현 시점에서 홈 서버로 가장 적절한 미니 PC 중 하나를 추천 드립니다 image 이니스프리 이니스프리 19.10.26.20:10 1750
472 구글 드라이브 API 사용시 파일 소유자 변경 5 image 네모 네모 18.07.08.21:41 1745
471 glob.glob()를 이용하여 recursive하게 하위 폴더까지 모든 파일과 디렉토리를 검색하기 이니스프리 이니스프리 20.08.12.16:22 1742
470 [Scipy] Wasserstein distance를 이용한 두 이미지 간 유사도 측정 1 이니스프리 이니스프리 20.05.29.19:36 1723