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

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님의 댓글"

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

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [중요공지] 추석 맞이 서버 업데이트 안내 5 마스터 마스터 25.10.09.02:20 78513
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 7 마스터 마스터 23.01.14.02:23 371952
552 일부 GIF 파일을 ImageMagick으로 처리 시 이미지가 깨지는 경우 해결법 image 제르엘 제르엘 25.05.18.02:25 1474
551 [Python] installing Geopandas in Windows (Trouble shooting) 1 이니스프리 이니스프리 24.10.25.20:10 1495
550 [Nextcloud] 프로세스가 kill 되는 문제에 관한 Troubleshooting 3 이니스프리 이니스프리 24.09.30.19:53 1794
549 [펌] Contabo VPS 관련 최근 정보글 image 이니스프리 이니스프리 24.09.29.21:11 1045
548 [Python] PDF 파일을 특정 페이지를 기준으로 두 개로 나누기 이니스프리 이니스프리 24.08.11.20:27 1676
547 [Python] Youtube API를 사용하지 않고 특정 채널의 모든 비디오 URL을 가져오기 이니스프리 이니스프리 24.06.09.22:12 1411
546 HDMI 단자의 QHD 출력을 정식으로 지원하지 않는 NVIDIA 그래픽 카드로 QHD 60 Hz 해상도 출력하기 2 image 제르엘 제르엘 24.06.09.17:45 2277
545 [Python] cannot import name 'TypeAliasType' from 'typing_extensions' 에러 대응방법 이니스프리 이니스프리 24.06.01.23:54 1146
544 [VSCode] 1개의 OS에 VSCode 여러 개를 설치 및 구동하기 이니스프리 이니스프리 24.05.26.05:09 1149
543 [Python] 리스트에 중복된 원소가 있는지 확인하는 함수 이니스프리 이니스프리 24.05.22.20:21 1286
542 [Python] random 함수가 계속하여 동일한 결과를 출력할 때 해결방법 이니스프리 이니스프리 24.05.15.19:32 1552
541 트래픽 절감 관련 모 커뮤니티 사이트의 회의 결과 이니스프리 이니스프리 24.05.15.16:51 1387
540 [Python] SSL: CERTIFICATE_VERIFY_FAILED에 대한 대처 방법 (2) 이니스프리 이니스프리 24.05.05.21:04 1339
539 [KT] 오피스넷 가정 설치 관련 이니스프리 이니스프리 24.05.05.00:28 1250
538 [Python] 쿠팡 크롤링할 때 소소한 팁 이니스프리 이니스프리 24.05.02.21:50 1182
537 [Python] dictionary 2개의 평균을 구하여 내림차순 정렬하기 이니스프리 이니스프리 24.04.21.17:29 1105
536 [Python] 독일어, 스페인어, 체코어 등 철자를 영문 알파벳으로 전환하기 이니스프리 이니스프리 24.04.21.17:15 1052
535 [Python] Tabulate 모듈로 작성한 테이블을 파일로 저장할 때 에러가 발생하는 경우 이니스프리 이니스프리 24.04.20.23:45 937
534 [Python] 변수의 이름을 반환하는 함수 이니스프리 이니스프리 24.04.20.23:29 1167
533 [Python] Table을 쉽게 만들어주는 모듈x2 이니스프리 이니스프리 24.04.18.22:04 827