nginx如何重定向信息
nginx 是一个灵活且高效的网络服务器,如果想要在nginx服务器中重定,你可以从下面挑选一个适合的方式。
简单且快速的 return
这是一个非常简单的设置方式,只需要个return
语句就可以了
return 301 https://example.com$request_uri;
你需要把这段代码放到nginx配置文件的server
代码块中,301
是永久重定向,你也可以设置成302
做一个临时重定向(不建议)。
一个完整的例子:
return 301 https://example.com$request_uri;
正则表达式 rewrite
如果return
不能满足你的复杂业务需求,你可以考虑下正则匹配重定向:
rewrite ^/foo/(bar)/(.*)$ https://$server_name/$1/$2 permanent;
同样这也是需要在server
代码块中,其中permanent
为301
永久跳转,若需要302
可修改为redirect
一个完整的例子:
server { listen 80; listen [::]:80; hostname example.com www.example.com; root /var/www/example.com/public; rewrite ^/foo/(bar)/(.*)$ $scheme://$server_name/$1/$2 permanent; }
又如:
server { listen 80; server_name www.fangyongle.com fangyongle.cn; if ($host != 'www.fangyongle.com' ) { rewrite ^/(.*)$ https://www.fangyongle.com/$1 permanent; } }
再如:
# 根据文件类型设置过期时间 location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ { if (-f $request_filename) { expires 1h; break; } }
使用Maps
如果你有一堆需要重定向的连接映射,你可以考虑在一个地方定义它,然后再通过if
来手动判断重定向。
首先定义重定向链接映射redirect-map.conf
map $request_uri $redirect_uri { /about.html /about-us; /customers.html /our-customers; /products.html /our-products; }
然后在server
代码块使用:
include redirect-map.conf; server { […] if ( $redirect_uri ) { return 301 $redirect_uri; } }
映射也可以有一些语法:
map $request_uri $redirect_uri { /about.html /about-us; /customers.html /our-customers; /products.html /our-products; # Match any url that ends in products.html or producs.htm ~products\.html?$ /our-products; # case-insensitive version of the above ~*products\.html?$ /our-products; # A named capture that maps # e.g. product-1234.html into /products/item-1234/overview ~product-(?<sku>\d+)\.html /products/item-$sku/overview; }
一些实用的重定向例子
http 重定向为 https
return 301 https://$host$request_uri;
统一规范域名
server_name example.com www.example.com example.net www.example.net _; if ( $host != $server_name ) { return 301 $scheme://$server_name$request_uri; }
含 www 和 不含 www 之间的重定向
# non-www to www if ( $host !~ ^www\. ) { return 301 $scheme://www.$host$request_uri; }
# www to non-www if ( $host ~ ^www\.(?<domain>.+)$ ) { return 301 $scheme://$domain$request_uri; }
附录
重定向中常用全局变量
$scheme // HTTP方法(如http,https),如:http $host // 请求主机头字段,否则为服务器名称,如:blog.fangyongle.com $server_name // 服务器名称,如:blog.fangyongle.com $request_uri // 包含请求参数的原始URI,不包含主机名,如:/2018/81.html?a=1&b=2 $request_filename // 当前请求的文件的路径名,由root或alias和URI request组合而成,如:/2013/81.htmlnginx 部分常用全局变量
nginx 部分常用全局变量
$remote_addr//获取客户端ip $binary_remote_addr//客户端ip(二进制) $remote_port//客户端port,如:50472 $remote_user//已经经过Auth Basic Module验证的用户名 $host//请求主机头字段,否则为服务器名称,如:blog.fangyongle.com $request//用户请求信息,如:GET ?a=1&b=2 HTTP/1.1 $request_filename//当前请求的文件的路径名,由root或alias和URI request组合而成,如:/2013/81.html $status//请求的响应状态码,如:200 $body_bytes_sent // 响应时送出的body字节数数量。即使连接中断,这个数据也是精确的,如:40 $content_length // 等于请求行的“Content_Length”的值 $content_type // 等于请求行的“Content_Type”的值 $http_referer // 引用地址 $http_user_agent // 客户端agent信息,如:Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.76 Safari/537.36 $args //与$query_string相同 等于当中URL的参数(GET),如a=1&b=2 $document_uri //与$uri相同 这个变量指当前的请求URI,不包括任何参数(见$args) 如:/2018/81.html $document_root //针对当前请求的根路径设置值 $hostname //如:centos53.localdomain $http_cookie //客户端cookie信息 $cookie_COOKIE //cookie COOKIE变量的值 $is_args//如果有$args参数,这个变量等于”?”,否则等于”",空值,如? $limit_rate//这个变量可以限制连接速率,0表示不限速 $query_string // 与$args相同 等于当中URL的参数(GET),如a=1&b=2 $request_body // 记录POST过来的数据信息 $request_body_file//客户端请求主体信息的临时文件名 $request_method //客户端请求的动作,通常为GET或POST,如:GET $request_uri //包含请求参数的原始URI,不包含主机名,如:/2018/81.html?a=1&b=2 $scheme //HTTP方法(如http,https),如:http $uri//这个变量指当前的请求URI,不包括任何参数(见$args) 如:/2018/81.html $request_completion//如果请求结束,设置为OK. 当请求未结束或如果该请求不是请求链串的最后一个时,为空(Empty),如:OK $server_protocol//请求使用的协议,通常是HTTP/1.0或HTTP/1.1,如:HTTP/1.1 $server_addr//服务器IP地址,在完成一次系统调用后可以确定这个值 $server_name//服务器名称,如:blog.fangyongle.com $server_port//请求到达服务器的端口号,如:80
Rewrite正则相关指令详解
nginx的rewrite
相当于apache的rewriterule
(大多数情况下可以把原有apache的rewrite
规则加上引号就可以直接使用),它可以用在server
,location
和IF
条件判断块中,命令格式如下:
rewrite <regex> <replacement> <flag>
正则表达式匹配
~
为区分大小写匹配~*
为不区分大小写匹配!~
和!~*
分别为区分大小写不匹配及不区分大小写不匹配
文件及目录匹配判断
-f
和!-f
用来判断是否存在文件-d
和!-d
用来判断是否存在目录-e
和!-e
用来判断是否存在文件或目录-x
和!-x
用来判断文件是否可执行
flag标记
last
- 基本上都用这个Flag。break
- 中止rewirte
,不在继续匹配redirect
- 返回临时重定向的HTTP状态302permanent
- 返回永久重定向的HTTP状态301
使用last
和break
实现URI
重写,浏览器地址栏不变。而且两者有细微差别:
使用
alias
指令必须用last
标记使用
proxy_pass
指令时,需要使用break
标记last
标记在本条rewrite
规则执行完毕后,会对其所在server{......}
标签重新发起请求,而break
标记则在本条规则匹配完成后,终止匹配。
更多Nginx相关技术文章,请访问Nginx教程栏目进行学习!
以上是nginx如何重定向信息的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

如何解决 Nginx 403 Forbidden 错误?检查文件或目录权限;2. 检查 .htaccess 文件;3. 检查 Nginx 配置文件;4. 重启 Nginx。其他可能原因还包括防火墙规则、SELinux 设置或应用程序问题。

服务器无权访问所请求的资源,导致 nginx 403 错误。解决方法包括:检查文件权限。检查 .htaccess 配置。检查 nginx 配置。配置 SELinux 权限。检查防火墙规则。排除其他原因,如浏览器问题、服务器故障或其他可能的错误。

解决 Nginx 跨域问题有两种方法:修改跨域响应头:添加指令以允许跨域请求,指定允许的方法和头,以及设置缓存时间。使用 CORS 模块:启用模块并配置 CORS 规则,允许跨域请求、方法、头和设置缓存时间。

在 Linux 中启动 Nginx 的步骤:检查 Nginx 是否已安装。使用 systemctl start nginx 启动 Nginx 服务。使用 systemctl enable nginx 启用在系统启动时自动启动 Nginx。使用 systemctl status nginx 验证启动是否成功。在 Web 浏览器中访问 http://localhost 查看默认欢迎页面。

问题的答案:304 Not Modified 错误表示浏览器已缓存客户端请求的最新资源版本。解决方案:1. 清除浏览器缓存;2. 禁用浏览器缓存;3. 配置 Nginx 允许客户端缓存;4. 检查文件权限;5. 检查文件哈希;6. 禁用 CDN 或反向代理缓存;7. 重启 Nginx。

如何在 Windows 中配置 Nginx?安装 Nginx 并创建虚拟主机配置。修改主配置文件并包含虚拟主机配置。启动或重新加载 Nginx。测试配置并查看网站。选择性启用 SSL 并配置 SSL 证书。选择性设置防火墙允许 80 和 443 端口流量。

确认 Nginx 是否启动的方法:1. 使用命令行:systemctl status nginx(Linux/Unix)、netstat -ano | findstr 80(Windows);2. 检查端口 80 是否开放;3. 查看系统日志中 Nginx 启动消息;4. 使用第三方工具,如 Nagios、Zabbix、Icinga。

查看 Nginx 运行状态的方法有:使用 ps 命令查看进程状态;查看 Nginx 配置文件 /etc/nginx/nginx.conf;使用 Nginx 状态模块启用状态端点;使用 Prometheus、Zabbix 或 Nagios 等监控工具。
