Nginx プロキシ axios リクエストと注意事項は何ですか?

WBOY
リリース: 2023-05-15 17:43:06
転載
1007 人が閲覧しました

1. nginx.conf 設定情報

nginx.conf には多くの設定情報があるため、この記事では axios と静的リソース リクエストの設定のみに焦点を当てます。共通の設定項目についても説明します。いくつかの設定項目に注意してください。具体的な設定は次のとおりです:

# 设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
 #连接超时时间
 keepalive_timeout 120;
 
 #gzip压缩开关及相关配置
 gzip on;
 gzip_min_length 1k;
 gzip_buffers  4 32k;
 gzip_http_version 1.1;
 gzip_comp_level 2;
 gzip_types  text/plain application/x-javascript text/css application/xml;
 gzip_vary on;
 gzip_disable "msie [1-6].";

 #设定实际的服务器列表 
 upstream zp_server{
 server 127.0.0.1:8089;
 }
 
 #http服务器 
 server {
 #监听80端口
 listen 80
 
 #定义服务名称
 server_name localthost;
 
 #首页
 index index.html
 
 #指向项目根目录
 root d:\project\src\main\webapp;
 
 #编码格式
 charset utf-8;
 
 #代理的路径(和upstream绑定),location 后面设置映射的路径
 location / {
  #代理配置参数
  proxy_connect_timeout 180;
  proxy_send_timeout 180;
  proxy_read_timeout 180;
  proxy_set_header host $host;
  proxy_set_header x-forwarder-for $remote_addr;
  proxy_pass http://zp_server/;
  
  #跨域相关设置
  add_header 'access-control-allow-origin' '*' always;
  add_header 'access-control-allow-credentials' 'true';
  add_header 'access-control-allow-headers' 'origin, x-requested-with, content-type, accept' always;
  }
  
  #配置静态资源 解决js css文件无法加载无法访问的问题,注意末尾不能有 /
  location ~ .*\.(js|css|jpg|png)$ {
  proxy_pass http://zp_server;
  } 
 }
}
ログイン後にコピー

2. proxy_pass

##nginx のスラッシュ問題により、proxy_pass は 2 つのタイプに分割されます:

  • 1 つのタイプには、IP とポート番号のみが含まれます (ポートの後の / も含まれないため、ここでは特別な注意が必要です)。たとえば、proxy_pass http://localhost:8080 のように、このメソッドは URI なしメソッドと呼ばれます。

  • もう 1 つは、ポート番号の後に他のパスがあり、/ が 1 つだけあるパス (proxy_pass http://localhost:8080/ など) やその他のパス (proxy_pass など) が含まれます。 http://localhost:8080/abc。

2.1 uri のないメソッドの場合

uri のないメソッドの場合、nginx は場所のパス部分を保持します。例:

location /api1/ {
 proxy_pass http://localhost:8080;
}
ログイン後にコピー

http://localhost/api1/xxx にアクセスすると、http://localhost:8080/api1/xxx

2.2 にプロキシされます。uri の場合method

uri メソッドの場合、nginx はエイリアスなどの置換メソッドを使用して URL を置換します。この置換は、

location /api2/ {
 proxy_pass http://localhost:8080/;
}
ログイン後にコピー

のようなリテラル置換にすぎません。 http にアクセスする場合 ://localhost/api2/xxx の場合、http://localhost/api2/ (末尾の / に注意) が http://localhost:8080/ に置き換えられ、残りの xxx が追加されます。 http://localhost:8080/xxx になります。

2.3 概要

server {
 listen    80;
 server_name localhost;

 location /api1/ {
  proxy_pass http://localhost:8080;
 }
 # http://localhost/api1/xxx -> http://localhost:8080/api1/xxx


 location /api2/ {
  proxy_pass http://localhost:8080/;
 }
 # http://localhost/api2/xxx -> http://localhost:8080/xxx


 location /api3 {
  proxy_pass http://localhost:8080;
 }
 # http://localhost/api3/xxx -> http://localhost:8080/api3/xxx


 location /api4 {
  proxy_pass http://localhost:8080/;
 }
 # http://localhost/api4/xxx -> http://localhost:8080//xxx,请注意这里的双斜线,好好分析一下。


 location /api5/ {
  proxy_pass http://localhost:8080/haha;
 }
 # http://localhost/api5/xxx -> http://localhost:8080/hahaxxx,请注意这里的haha和xxx之间没有斜杠,分析一下原因。

 location /api6/ {
  proxy_pass http://localhost:8080/haha/;
 }
 # http://localhost/api6/xxx -> http://localhost:8080/haha/xxx

 location /api7 {
  proxy_pass http://localhost:8080/haha;
 }
 # http://localhost/api7/xxx -> http://localhost:8080/haha/xxx

 location /api8 {
  proxy_pass http://localhost:8080/haha/;
 }
 # http://localhost/api8/xxx -> http://localhost:8080/haha//xxx,请注意这里的双斜杠。
}
ログイン後にコピー

以上がNginx プロキシ axios リクエストと注意事項は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:yisu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!