这是一个非常大略的设置办法,只须要个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标记则在本条规则匹配完成后,终止匹配。