nginx配置proxy_pass URL末尾加与不加/(斜线)的区别 Nginx 路径符号匹配规则,通配符

本文详细解析了Nginx中proxy_pass配置项在URL结尾加与不加斜线的区别,以及Nginx路径符号匹配规则,包括精确匹配、前缀匹配、正则匹配等,帮助读者理解并正确配置Nginx代理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

nginx配置proxy_pass URL末尾加与不加/(斜线)的区别

nginx在配置proxy_pass的时候 URL结尾加斜线(/)与不加的区别和注意事项

假设访问路径的 /pss/bill.html

加/斜线的情况

location /pss/ {
proxy_pass http://127.0.0.1:18081/;
}

被代理的真实访问路径为:http://127.0.0.1:18081/bill.html

 

 不加/斜线的情况

location /pss/ {
proxy_pass http://127.0.0.1:18081;
}

 被代理的真实访问路径为:http://127.0.0.1:18081/pss/bill.html

转自:https://www.cnblogs.com/peachyy/p/7649794.html

 

Nginx 路径符号匹配规则,通配符

1,Nginx路径符号匹配介绍:
= 表示精确匹配
^~ 表示uri以某个常规字符串开头,大多情况下用来匹配url路径,nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。
~ 正则匹配(区分大小写)
~* 正则匹配(不区分大小写)
!~ 和 !~*分别为区分大小写不匹配及不区分大小写不匹配 的正则
/ 任何请求都会匹配
2,符号的优先级
首先匹配 =,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。

例子,有如下匹配规则:

location = / {  

   #规则A  

}  

location = /login {  

   #规则B  

}  

location ^~ /static/ {  

   #规则C  

}  

location ~ \.(gif|jpg|png|js|css)$ {  

   #规则D  

}  

location ~* \.png$ {  

   #规则E  

}  

location !~ \.xhtml$ {  

   #规则F  

}  

location !~* \.xhtml$ {  

   #规则G  

}  

location / {  

   #规则H  

}  

 
访问根目录/, 比如http://localhost/ 将匹配规则A

访问 http://localhost/login 将匹配规则B,http://localhost/register 则匹配规则H

访问 http://localhost/static/a.html 将匹配规则C

访问 http://localhost/a.gif, http://localhost/b.jpg 将匹配规则D,规则E不起作用,而 http://localhost/static/c.png 则优先匹配到规则C

访问 http://localhost/a.PNG 则匹配规则E,而不会匹配规则D,因为规则E不区分大小写。

访问 http://localhost/a.xhtml 不会匹配规则F和规则G,http://localhost/a.XHTML不会匹配规则G,因为不区分大小写。规则F,规则G属于排除法,符合匹配规则但是不会匹配到,所以想想看实际应用中哪里会用到。

访问 http://localhost/category/id/1111 则最终匹配到规则H,因为以上规则都不匹配,这个时候应该是nginx转发请求给后端应用服务器,比如FastCGI(php),tomcat(jsp),nginx作为方向代理服务器存在。

3,简单通用配置
静态动态分离,除了静态资源以外的请求都交给Tomcat处理.

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

location ^~ /static/ {  
    root /webroot/static/;  
}  

location ~* \.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ {  
    root /webroot/res/;  
}  
 

原文:https://blog.youkuaiyun.com/u012946310/article/details/84293031 
 

################ nginxconf ############# server { listen 443 ssl; server_name admin.glgw.com; root /opt/b2b-web/admin; #charset koi8-r; #access_log /var/log/nginx/host.access.log main; #keepalive_timeout 100; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; ssl_certificate /root/cr/glgw.com.pem; # 证书路径 ssl_certificate_key /root/cr/glgw.com.key; # 请求认证 key 的路径 ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; gzip on; gzip_static on; # 开启时 打包时使用压缩插件打包 这样需要使用压缩文件时会自动载压缩文件 而不在消耗CPU进行压缩 gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; gzip_vary on; gzip_disable "MSIE [1-6]\."; gzip_proxied off; location /v3 { proxy_pass http://127.0.0.1:8501/v3; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { try_files $uri $uri/ /index.html last; } location /resources { proxy_pass http://127.0.0.1:8501/resources; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } server { listen 80; server_name admin.glgw.com; location / { rewrite ^(.*)$ https://admin.glgw.com$1 permanent; } } server { listen 443 ssl; server_name m.glgw.com; root /opt/b2b-web/h5; #charset koi8-r; #access_log /var/log/nginx/host.access.log; #keepalive_timeout 100; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; ssl_certificate /root/cr/glgw.com.pem; # 证书路径 ssl_certificate_key /root/cr/glgw.com.key; # 请求认证 key 的路径 ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; gzip on; gzip_static on; # 开启时 打包时使用压缩插件打包 这样需要使用压缩文件时会自动载压缩文件 而不在消耗CPU进行压缩 gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; gzip_vary on; gzip_disable "MSIE [1-6]\."; gzip_proxied off; location /v3 { proxy_pass http://127.0.0.1:8501/v3; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { try_files $uri $uri/ /index.html last; } } server { listen 80; server_name m.glgw.com; location / { rewrite ^(.*)$ https://m.glgw.com$1 permanent; } } server { listen 443 ssl; server_name image.glgw.com; #charset koi8-r; #access_log /var/log/nginx/host.access.log main; #keepalive_timeout 100; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; ssl_certificate /root/cr/glgw.com.pem; # 证书路径 ssl_certificate_key /root/cr/glgw.com.key; # 请求认证 key 的路径 ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; gzip on; gzip_static on; # 开启时 打包时使用压缩插件打包 这样需要使用压缩文件时会自动载压缩文件 而不在消耗CPU进行压缩 gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; gzip_vary on; gzip_disable "MSIE [1-6]\."; gzip_proxied off; location /unsafe { proxy_pass http://127.0.0.1:8888; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { # proxy_pass http://127.0.0.1:9000/; proxy_pass http://127.0.0.1:9090/; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } server { listen 80; server_name image.glgw.com; location / { rewrite ^(.*)$ https://image.glgw.com$1 permanent; } } server { listen 443 ssl; server_name www.glgw.com; root /opt/b2b-web/pc; #charset koi8-r; #access_log /var/log/nginx/host.access.log main; #keepalive_timeout 100; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; ssl_certificate /root/cr/glgw.com.pem; # 证书路径 ssl_certificate_key /root/cr/glgw.com.key; # 请求认证 key 的路径 ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; gzip on; gzip_static on; # 开启时 打包时使用压缩插件打包 这样需要使用压缩文件时会自动载压缩文件 而不在消耗CPU进行压缩 gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; gzip_vary on; gzip_disable "MSIE [1-6]\."; gzip_proxied off; location /v3 { proxy_pass http://127.0.0.1:8501/v3; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { try_files $uri $uri/ /index.html last; } } server { listen 80; server_name www.glgw.com; location / { rewrite ^(.*)$ https://www.glgw.com$1 permanent; } } server { listen 443 ssl; server_name seller.glgw.com; root /opt/b2b-web/seller; #charset koi8-r; #access_log /var/log/nginx/host.access.log main; #keepalive_timeout 100; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; ssl_certificate /root/cr/glgw.com.pem; # 证书路径 ssl_certificate_key /root/cr/glgw.com.key; # 请求认证 key 的路径 ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; gzip on; gzip_static on; # 开启时 打包时使用压缩插件打包 这样需要使用压缩文件时会自动载压缩文件 而不在消耗CPU进行压缩 gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; gzip_vary on; gzip_disable "MSIE [1-6]\."; gzip_proxied off; location /v3 { proxy_pass http://127.0.0.1:8501/v3; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; error_page 502 @start-webpack-dev-server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-Port $remote_port; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { try_files $uri $uri/ /index.html last; } } server { listen 80; server_name seller.glgw.com; location / { rewrite ^(.*)$ https://seller.glgw.com$1 permanent; } } server { listen 443 ssl; server_name im.glgw.com; root /opt/b2b-web/im; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; ssl_certificate /root/cr/glgw.com.pem; # 证书路径 ssl_certificate_key /root/cr/glgw.com.key; # 请求认证 key 的路径 ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; location /socket.io/ { proxy_pass http://127.0.0.1:8212; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } location /websocket/ { proxy_pass http://127.0.0.1:8212; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } location / { try_files $uri $uri/ /index.html last; } } server { listen 80; server_name im.glgw.com; location / { rewrite ^(.*)$ https://im.glgw.com$1 permanent; } } 你帮我解读一下这个配置文件具体内容
06-10
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值