머리말
프로젝트 개발 시 우리가 사용하는 도메인 이름이 백엔드 인터페이스의 도메인 이름과 일치하지 않기 때문에 도메인 간 문제가 발생하는 경우가 많습니다. 개발 환경에서는 프록시를 구성하여 도메인 간 문제를 해결할 수 있지만 패키징 및 배포 후에는 다른 방법을 사용하여 도메인 간 문제를 해결해야 합니다. 이 기사에서는 vue-cli3를 사용하여 도메인 간 패키징 및 배포하는 방법을 소개합니다.
1. 교차 출처란 무엇입니까?
CORS(교차 출처 리소스 공유)는 웹 페이지가 다른 소스에서 리소스를 가져오는 것을 방지하는 브라우저의 동일 출처 정책의 제한 사항입니다. 동일한 프로토콜, 도메인 이름 및 포트 번호. 원본이 아닌 소스 경로에서 요청이 시작되면 브라우저는 요청을 거부합니다.
2. vue-cli3 패키징의 여러 모드
vue-cli3에서는 패키징이 세 가지 모드로 나뉩니다.
- 테스트 모드(빌드-테스트)
테스트 모드는 코드를 개발 환경 실행 가능 모드로 패키징합니다. 소스맵 디버깅 기능을 자동으로 활성화합니다. - 빌드 모드(build-prod)
빌드 모드는 코드를 압축하고 난독화하며 프로덕션 환경에 배포하는 데 적합합니다. - 생성 및 미리보기 모드(서브)
서브 모드는 코드를 핫 업데이트하고 개발 중 미리보기 및 테스트에 적합한 미리보기 서비스를 제공합니다.
3. 크로스 도메인 솔루션 패키징 및 배포
크로스 도메인을 패키징하고 배포할 때 크로스 도메인 문제를 해결하려면 nginx를 사용하여 역방향 프록시를 수행해야 합니다.
nginx는 Windows, Linux, Mac 등 다양한 운영 체제에서 실행할 수 있는 고성능 웹 서버입니다. 매우 강력하며 역방향 프록시, 로드 밸런싱, 캐싱 등에 사용할 수 있습니다.
- Install nginx
Linux 환경에서는 다음 명령을 통해 nigix를 설치할 수 있습니다.
sudo apt-get update sudo apt-get install nginx
- Configure nginx
nginx를 설치한 후 도메인 간 문제를 해결하려면 nginx를 구성해야 합니다.
먼저, 일반적으로 /etc/nginx/conf.d/default.conf에서 nginx 구성 파일을 찾아야 합니다. 다음 명령을 통해 nginx 구성 파일을 엽니다.
sudo vim /etc/nginx/conf.d/default.conf
그런 다음 다음과 같이 서버 세그먼트를 찾습니다. :
server { listen 80; server_name localhost; #charset koi8-r; #access_log /var/log/nginx/host.access.log main; location / { root /usr/share/nginx/html; index index.html index.htm; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ .php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ .php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /.ht { # deny all; #} }
위치 세그먼트 아래에 역방향 프록시를 구성해야 합니다. 예를 들면 다음과 같습니다.
location /api { proxy_pass http://192.168.0.100:8080; # 后端API地址 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-NginX-Proxy true; proxy_http_version 1.1; proxy_connect_timeout 600; proxy_read_timeout 600; proxy_send_timeout 600; proxy_buffer_size 64k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 128k; # 解决跨域 add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Credentials' 'true'; add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS'; add_header 'Access-Control-Allow-Headers' 'Authorization,DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type'; # 缓存时间,单位秒。这里设置的是6小时 expires 21600s; # 收到304响应后,再次请求的时间间隔 proxy_cache_valid 200 304 12h; }
그중 Proxy_pass 다음의 주소는 백엔드 API 주소로 변경되어야 하며 add_header는 교차 도메인 문제를 해결합니다.
- vue.config.js 구성 수정
vue-cli3에서는 vue.config.js의 publicPath를 구성하여 패키지 파일을 도메인 이름과 독립적으로 만들 수 있습니다. 구체적인 구성은 다음과 같습니다.
module.exports = { publicPath: '', devServer: { // 设置跨域代理 proxy: { '/api': { target: 'http://192.168.0.100:8080', // 后端API地址 ws: true, changOrigin: true, pathRewrite: { '^/api': '' } } } }, chainWebpack: (config) => { config.optimization.delete('splitChunks'); } }
Among /api는 백엔드 API 주소의 접두사이고 대상 구성은 백엔드 API 주소입니다.
- Packaging and 배포
위 구성 후 vue 프로젝트를 패키징하고 배포할 수 있습니다. 패키징이 완료된 후 /dist 디렉터리의 모든 파일을 nginx 구성의 루트 디렉터리(일반적으로 /usr/share/nginx/html)에 복사한 다음 nginx 서비스를 다시 시작합니다.
sudo service nginx restart
이때, 우리는 도메인 전반에 걸쳐 vue-cli3 패키징 및 배포를 구현하는 데 성공했습니다.
요약
이 글에서는 nginx 역방향 프록시를 사용하여 vue-cli3 패키징 및 배포의 도메인 간 문제를 해결하는 방법을 소개합니다. 위의 구성을 통해 크로스 도메인 문제를 해결하고 프로덕션 환경에 배포할 수 있습니다. 물론 nginx에 대한 사용자 액세스 권한 활성화 등 배포 과정에서 보안 문제에 주의해야 합니다. 물론, jsonp, websocket 등과 같은 도메인 간 문제를 해결하기 위해 다른 방법을 사용할 수도 있습니다.
위 내용은 도메인 전반에 걸친 Vue 패키징 및 배포의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

usestate () isareacthookusedtomanagestatefunctionalcomponents.1) itinitializesandupdatesstate, 2) workaledtthetThetThepleFcomponents, 3) canleadto'Stalestate'ifnotusedCorrecrally 및 4) performancanoptimizedUsecandusecaldates.

Reactispopularduetoitscomponent 기반 아카데입, 가상, Richcosystem 및 declarativenature.1) 구성 요소 기반 ectureallowsforeusableuipieces, Modularityandmainability 개선 가능성.

TodebugreactApplicationseffective, UsetheseStradegies : 1) 주소 propdrillingwithContapiorredux.2) handleaSnchronousOperationswithUsestAndUseefect, abortControllerTopReceConditions.3) 최적화 formanceSeMoAnduseCalbackTooid

usestate () inreactAllowsStateManagementInfunctionalComponents.1) itsimplifiessTatemanagement, 2) usethepRevCountFunctionToupDatesTestateSpreviousValue, PropeingStaleScallanceBackferperperperperperperperperperperperperpertoptiMizatio

chelectionSimple, IndependentStateVaribles; useUserEducer () useuserEducer () forcomplexStateLogicor () whenStatedSonpreviousState.1) usestate () isidealforsimpleupdatesliketogglingabooleorupdatingacounter.2) usbetterformanagingmentiplesub-vvalusorac

Usestate는 클래스 구성 요소 및 기타 상태 관리 솔루션보다 우수합니다. 국가 관리를 단순화하고 코드를 더 명확하게하고 읽기 쉽고 React의 선언적 특성과 일치하기 때문입니다. 1) Usestate는 함수 구성 요소에서 상태 변수를 직접 선포 할 수있게합니다. 2) 후크 메커니즘을 통해 다시 렌더링하는 동안 상태를 기억합니다.

useUsestate () forlocalcomponentStateManagement; 고려 사항 forglobalstate, complexlogic, orperformanceissues.1) usestate () isidealforsimple, localstate.2) useglobalstatesolutionslikereduxorcontextforsharedstate.3) optforredooxtoolkitormobxcomcoccomcoccomcoccomcoccomcoccomcoccomcoccomcoccomporccomcoccomporccomcoccomport

reusablecomponentsinreacececodemainabenabilityandefficiency는 hallowingesamecomponentacrossdifferentpartsofanapplicationorprojects.1) 그들을 retuduceredundancyandsimplifyupdates.2) theyseconsistencyinuserexperience.3) theyquireoptim


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
