-
[ react ] Axios 호출, Proxy를 이용하여 크로스브라우징 문제(CORS 이슈) 해결하기성장과정(dev)/Frontend(feat. Vue, Next.js) 2020. 11. 6. 17:41
* npm 라이브러리 설치
$ npm install axios --save
* server와 client port번호 분리 ( server는 5000, client는 3000번 )
server쪽 index.js에서 listener에 포트번호설정
const port = 5000 //포트번호 ... // api 추가 app.get('/api/hello', (req, res) => { res.send("안녕하세요 !") }) app.listen(port, () => { console.log(`Example app listening at http://localhost:${port}`) })
* frontend에서 server 호출
- axios를 호출하는 컴포넌트 전체소스
import React, {useEffect} from 'react' import axios from 'axios' function LandingPage () { useEffect( () => { axios.get( 'http://localhost:5000/api/hello' ) .then( response => console.log ( response.data ) ) }, [] ) return ( <div> LandingPage </div> ) } export default LandingPage
* 위와같이 호출 시 같은 서버에서 호출하는 것이 아니므로 에러발생
* 에러원인
CORS( Cross-Origin Resource Sharing ) policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
> 각 서버를 origin이라고 명시
* 해결방안 4가지
1. 개발자도구 이용
2. JSONP 라는 방식으로 모든 request를 get으로 변경하여 요청을 보냄
3. 서버에서 해당 client의 요청을 허용한다는 정의 & Client에서 허가를 받기위한 특정 파라미터를 보낸다
4. Proxy 사용
* 4번방법 Proxy를 사용하여 크로스브라우징 문제 해결하기
참고) create-react-app.dev/docs/proxying-api-requests-in-development/
1. $ npm install http-proxy-middleware --save
2. 참고문서대로 내용입력
- front 경로의 src 아래에 setupProxy.js 파일생성
- 접근하려는 서버 포트에 대해 proxy 정의( 예제는 node 서버가 5000번 )
const { createProxyMiddleware } = require('http-proxy-middleware'); module.exports = function(app) { app.use( '/api', createProxyMiddleware({ target: 'http://localhost:5000', changeOrigin: true, }) ); };
4. 노드서버를 호출하는 곳에서 axios.get( 'http://locathost:5000/api/hello' )라고 정의되어있던 부분을 axios.get( '/api/hello' ) 로 변경
5. npm run start
6. 성공!
* location.href 사용법
기존에 자바스크립트에서 location.href = "/login";
이렇게 사용했다면
react에서는 props.history.push( "/login" )
ex) 로그아웃 시
function LandingPage ( props ) { useEffect( () => { axios.get( '/api/hello' ) .then( response => console.log ( response.data ) ) }, [] ) const onClickHandler = () => { axios.get("/api/users/logout" ) .then( response => { if( response.data.success ) { props.history.push( "login" ) } else { alert( '로그아웃에 실패하였습니다.' ) } }) } return ( <div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center', width: '100%', height: '100vh'}}> <h2>시작 페이지</h2> <button onClick={onClickHandler}>로그아웃</button> </div> ) }
프록시 관련 추가설명 =======================================================
* Proxy란?
유저와 인터넷 사이의 중계서버
* 사용자와 인터넷 사이에서 proxy server의 역할?
- 요청을 하는 사용자의 ip를 proxy에서 변경할 수 있으므로 인터넷에서 접근하는 사람의 ip를 모르게 한다.
- 방화벽 기능
- 필터기능
- 프록시서버의 자체저장공간(캐시, 공유데이터)이 존재하기 때문에 인터넷까지 가지 않아도 static같은 데이터를 가져올 수 있다.
* 사용이유?
- 사용자에 대한 인터넷 사용제어
- 캐쉬를 이용하여 빠른 인터넷 이용 제공
- 보안 제공 (ip관련)
'성장과정(dev) > Frontend(feat. Vue, Next.js)' 카테고리의 다른 글
[react] HOC를 사용한 페이지별 접근인증 (0) 2020.11.16 [concurrently] react front서버, nodejs back 서버 동시에 실행하기 (0) 2020.11.09 [nodejs] git 연동하기 / terminal에서 git사용하기 (0) 2020.10.30 [node js] mongoDB 연결하기 (0) 2020.10.23 [node js, react 입문] inflearn 강의 node js로 프로젝트 생성하기 (0) 2020.10.18