欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Nginx代理axios請求以及注意事項詳解

 更新時間:2019年08月11日 10:33:47   作者:Clearlove  
這篇文章主要給大家介紹了關于Nginx代理axios請求以及注意事項的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

近期寫個小demo,因為用到某大廠的在線數(shù)據(jù),接口做了跨域限制,所以利用Nginx代理來解決這些問題。

1. nginx.conf 配置信息

由于nginx.conf配置信息較多,本篇只關注跟axios和靜態(tài)資源請求設置,順便也將常見的一些配置項備注一下。具體設置如下:

# 設定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 {
 #監(jiān)聽80端口
 listen 80
 
 #定義服務名稱
 server_name localthost;
 
 #首頁
 index index.html
 
 #指向項目根目錄
 root D:\project\src\main\webapp;
 
 #編碼格式
 charset utf-8;
 
 #代理的路徑(和upstream綁定),location 后面設置映射的路徑
 location / {
  #代理配置參數(shù)
  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;
  }
  
  #配置靜態(tài)資源 解決js css文件無法加載無法訪問的問題,注意末尾不能有 /
  location ~ .*\.(js|css|jpg|png)$ {
  proxy_pass http://zp_server;
  } 
 }
}

2. proxy_pass的斜杠問題

Nginx的官網(wǎng)將proxy_pass分為兩種類型:

  • 一種是只包含IP和端口號的(連端口之后的/也沒有,這里要特別注意),比如proxy_pass http://localhost:8080,這種方式稱為不帶URI方式;
  • 另一種是在端口號之后有其他路徑的,包含了只有單個/的,如proxy_pass http://localhost:8080/,以及其他路徑,比如proxy_pass http://localhost:8080/abc。

2.1 對于不帶URI方式

對于不帶URI方式,Nginx將會保留location中路徑部分,比如:

location /api1/ {
 proxy_pass http://localhost:8080;
}

在訪問http://localhost/api1/xxx時,會代理到http://localhost:8080/api1/xxx

2.2 對于帶URI方式

對于帶URI方式,nginx將使用諸如alias的替換方式對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負載均衡健康檢查性能提升

    Nginx負載均衡健康檢查性能提升

    這篇文章主要為大家介紹了Nginx負載均衡健康檢查性能提升,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • Nginx服務器下配置使用索引目錄的教程

    Nginx服務器下配置使用索引目錄的教程

    這篇文章主要介紹了Nginx服務器下配置使用索引目錄的教程,包括自帶的auto_index和使用fancy插件美化的用法,需要的朋友可以參考下
    2016-01-01
  • 使用Nginx作緩存服務器以及刪除其緩存文件的方法

    使用Nginx作緩存服務器以及刪除其緩存文件的方法

    這篇文章主要介紹了使用Nginx作緩存服務器以及刪除其緩存文件的方法,作cache時需要注意一下磁盤的IO瓶頸,需要的朋友可以參考下
    2015-11-11
  • Nginx處理跨域問題小結

    Nginx處理跨域問題小結

    這篇文章主要介紹了Nginx處理跨域問題小結,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-01-01
  • nginx ServerName匹配規(guī)則實現(xiàn)

    nginx ServerName匹配規(guī)則實現(xiàn)

    本文主要介紹了nginx ServerName匹配規(guī)則實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2007-02-02
  • 深入理解Nginx之error_page模塊的使用

    深入理解Nginx之error_page模塊的使用

    error_page是nginx一個重要的指令,作用是定制化服務器錯誤頁面,本文主要介紹了Nginx之error_page模塊的使用,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • Nginx如何根據(jù)前綴路徑轉發(fā)到不同的Flask服務

    Nginx如何根據(jù)前綴路徑轉發(fā)到不同的Flask服務

    這篇文章主要介紹了Nginx如何根據(jù)前綴路徑轉發(fā)到不同的Flask服務,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • nginx服務器通過配置來解決API的跨域問題

    nginx服務器通過配置來解決API的跨域問題

    這篇文章主要給大家介紹了關于nginx服務器是如何配置來解決API跨域問題的相關資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-05-05
  • Linux上搭載Nginx負載均衡配置使用案例詳解

    Linux上搭載Nginx負載均衡配置使用案例詳解

    這篇文章主要介紹了Linux上搭載Nginx負載均衡配置使用案例詳解,針對此情況而衍生出來的一種廉價有效透明的方法以擴展現(xiàn)有網(wǎng)絡設備和服務器的帶寬、增加吞吐量、加強網(wǎng)絡數(shù)據(jù)處理能力、提高網(wǎng)絡的靈活性和可用性的技術就是負載均衡(Load?Balance),需要的朋友可以參考下
    2022-01-01
  • 淺談nginx反向代理中神奇的斜線

    淺談nginx反向代理中神奇的斜線

    這篇文章主要介紹了淺談nginx反向代理中神奇的斜線,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09

最新評論