>운영 및 유지보수 >엔진스 >Nginx 리버스 프록시 크로스 도메인 기본 구성 방법

Nginx 리버스 프록시 크로스 도메인 기본 구성 방법

WBOY
WBOY앞으로
2023-05-13 21:49:101434검색

nginx 인터페이스 서비스 리버스 프록시 기본 구성

server {
  listen 8443; # 监听的端口号
  server_name a.test.com; # 服务器名称
  client_max_body_size 100m;  # 定义读取客户端请求头的超时时间
  ssl on;
  ssl_certificate test.pem;
  ssl_certificate_key test.key;
  ssl_session_timeout 5m;
  ssl_protocols sslv3 tlsv1.2;
  ssl_ciphers ecdhe-rsa-aes256-sha384:aes256-sha256:rc4:high:!md5:!anull:!enull:!null:!dh:!edh:!aesgcm;
  ssl_prefer_server_ciphers on;
  location / {
    root /test-static-app; # 静态资源目录
    index index.html index.htm;
    try_files $uri $uri/ /index.html; # 动态解析目录,配合vue的history模式
  }
}

기본 구성은 페이지와 정적 서버의 기본 기능을 구현하며, vue의 히스토리 모드 사용 시 경로 확인을 구현할 수 있습니다. 또한 인터페이스 서버에 대한 통합 전달을 달성하려면 백엔드 개발자와 함께 인터페이스 이름의 접두사를 지정해야 합니다. 예를 들어, 이때 모든 인터페이스의 상대 경로는 api로 시작됩니다. 다음 구성(이전 위치와 동일),

...
location /api {
  proxy_pass https://b.test.com; # 设置代理服务器的协议和地址
  proxy_cookie_domain b.test.com a.test.com; # 修改cookie,针对request和response互相写入cookie
}    
...

는 주로 Proxy_pass를 사용하여 a.test.com의 /api/x 인터페이스를 b.test.com으로 전달합니다. 프로세스는 대략 다음과 같습니다.

쿠키의 주요 상호 작용은 Proxy_cookie_domain입니다. 위의

proxy_cookie_domain b.test.com a.test.com;
Nginx 리버스 프록시 크로스 도메인 기본 구성 방법 단락은 a.test.com과 b.test.com 도메인 이름 간의 쿠키 전송 및 쓰기 저장을 실현합니다.

노드를 사용하여 시뮬레이션하면 대략 다음과 같습니다

module.exports = (router) => {
 router.get('/api/index/getcmsinfo', async function (ctx, next) {
  // 接口转发
  let result = await superagent.post('https://b.test.com/api/card/home').set(browsermsg)
  // 获取返回的set-cookie,并设置header
  let setcookie = result.headers['set-cookie']
  if (setcookie) {
    ctx.response.header['set-cookie'] = setcookie
  }
  // 返回
  ctx.response.body={
    success: true,
    result: result.body 
  }
 })
}

결론적으로 nginx 리버스 프록시의 본질은 사실 인터페이스 서비스의 전달과 헤더 처리에 있습니다. .

일반적인 오해

1. 쓸데없는 아카헤더?

인터넷의 많은 nginx 크로스 도메인 설정에는

add_header 'access-control-allow-origin' '*';
add_header 'access-control-allow-credentials' "true"; 
add_header access-control-allow-headers x-requested-with;

와 같은 크로스 도메인 헤더 설정과 관련된 콘텐츠가 추가되었습니다. 위의 원칙에 대해 생각해 보세요. 이것이 여전히 유용하다고 생각하십니까? aca(access-control-allow-) 시리즈의 헤더는 CORS에서 도메인 간 협상을 위해 구성되어 있습니다. 여기서 바지를 벗고 방귀를 뀌는 것은 단순히 불필요합니다.

2.proxy_pass 도메인 이름에 'slash/'가 포함되어 있나요?


마찬가지로 일부 네티즌들이 Proxy_pass를 구성하면 아래와 같이 끝에 슬래시를 추가하고 오류가 보고되고 인터페이스를 찾을 수 없다고 말하는 것을 인터넷에서 봤습니다~ 뭐가 문제인가요~

...
location /api {
  #proxy_pass https://b.test.com;
  proxy_pass https://b.test.com/;
}    
...

이것을 보세요. Proxy_pass의 기능은 요청을 캡처하는 것입니다. 슬래시를 추가한다는 것은 모든 /api 요청이 루트 디렉터리로 전달된다는 것을 의미합니다. 이는 /api가 /로 대체된다는 의미입니다. 경로가 변경됩니다. 레이어/API 하나가 누락되었습니다. 슬래시를 추가하지 않으면 어떻게 되나요? 이는 b.test.com이라는 도메인 이름으로 전달될 때 /api 경로가 손실되지 않음을 의미합니다.

이 경우 백엔드 인터페이스에 /api와 같은 사전 정의된 접두사가 있으면 여기서 슬래시를 구성할 필요가 없습니다. 또 다른 경우에는 백엔드 인터페이스가 동일하며 통합 접두사가 없습니다. 여기서는 /api와 같은 통합 접두사를 구별한 다음 모든 프런트엔드 인터페이스에 추가하고 슬래시를 추가하여 교체해야 합니다. ~

위 내용은 Nginx 리버스 프록시 크로스 도메인 기본 구성 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제