搜索
简帛阁>技术文章>URL重定向,rewrite命令

URL重定向,rewrite命令

前言

环境:centos7.9 nginx1.8
当我们访问一个地址如:http://www.baidu.com/,你会发现地址变成了:https://www.baidu.com/,由http变成了https,类似的,当我们访问一个地址http://AAAAA.com,地址跳转到了http://BBBB.com,我们称之为URL重定向,或称之为URL跳转,nginx中使用rewrite指令结合正则表达式来实现URL重定向。

return语法

return语法只能放在server、location、if中,该指令用于结束规则的执行并返回状态码给客户端。
示例:

location = /50x.html {<!-- -->
            return 403;			#直接return一个状态码返回给客户端
        }

rewrite语法

指令语法:rewrite regex replacement [flag];(即 rewrite 匹配内容 替代内容 标记;)
默认值:none
应用位置:server、location、if
rewrite是实现URL重定向的重要指令,它根据regex(正则表达式)来匹配内容跳转到replacement,结尾是flag标记。

常用正则表达式:

字符描述
\将后面接着的字符标记为一个特殊字符或者一个原义字符或一个向后引用
^匹配输入字符串的起始位置
$匹配输入字符串的结束位置
*匹配前面的字符零次或者多次
+匹配前面字符串一次或者多次
?匹配前面字符串的零次或者一次
.匹配除“\n”之外的所有单个字符
(pattern)匹配括号内的pattern

rewrite 最后一项flag标记:

标记说明
last本条规则匹配完成后继续向下匹配新的location URI规则,客户端地址不会发生跳转
break本条规则匹配完成后即刻终止,不再继续向下匹配任何规则,客户端地址不会发生跳转
redirect返回302临时重定向,浏览器地址会显示为跳转后的地址
permanent返回301永久重定向,浏览器地址会显示为跳转后的地址

rewrite匹配顺序

当你写了多条rewrite,rewrite匹配顺序是从上往下匹配,匹配到之后就不再匹配余下的rewrite规则。

rewrite示例

资源重定向:

[root@iflytek conf.d]# vim rewrite.conf 		#创建一个虚拟机
server{<!-- -->
	listen 9089;
	server_name localhost;
	location /{<!-- -->
	root /usr/local/nginx/html/rewrite;
	index index.html;
	try_files $uri $uri/ /index.html;
	rewrite /index.php /index.html last;	#使用rewrite命令进行资源重定向,模拟客户端访问index.php重定向到index.html
	}
}

#创建index.html文件
[root@iflytek conf.d] mkdir /usr/local/nginx/html/rewrite
[root@iflytek conf.d] vim /usr/local/nginx/html/rewrite/index.html

网页模拟访问index.php(实际并没有这个文件)看是否成功重定向,如下图所示:

域名重定向(以小米官网为例):

server{<!-- -->
    listen 80;
    server_name www.xiaomi.com;					#旧域名www.xiaomi.com
    rewrite / www.mi.com permanent;				#该旧域名的全部请求都会永久重定向到www.mi.com
    }
    .......
}
server{<!-- -->
    listen 80;
    server_name www.mi.com;						#新的域名www.mi.com
    root  html/mi/;	
    }
    .......
}
#以上域名要能解析(本地host解析或dns解析),这样在浏览器访问http://www.xiaomi.com时就会跳转到http://www.mi.com

1ApacheRewrite的主要功能就是实现URL的跳转和隐藏真实地址,基于Perl语言的正则表达式规范。平时帮助我们实现拟静态,拟目录,域名跳转,防止盗链等2ApacheRewrite的配置Ap
当我们在规划网站路径时,为了保留搜索引擎收录避免404的同时做到升级,常用到定向跳转和URL重写。定向(redirect)在Caddy中为redir指令。https://caddyserverc
在传统ASPNET程序中,我们可以通过配置IIS的“URL重写”功能实现将HTTP请求定向为HTTPS。但是该方法在ASPNETCore应用中不再工作。在ASPNETCore应用中,我们可以通过一个
需求,将http://localhost:80/index/abcrewrite为http://localhost:80/aaaphp/abc访问网站时只输入http://localhost:80/i
象下面两行伪代码:1setCookie();2redirect(new_web_url);首先设置一个Cookie,然后定向到另外一个网址,这个网址跟当前网站的域名不同在多数情况下这两行代码执行毫
(1)去除httpdconf文件中LoadModulerewrite_modulemodules/mod_rewriteso前面的号;(2)然后再在httpdconf中书写如下规则在apache的配置
apache开启定向rewrite的实现方法1开启定向模块$lns/etc/apache2/modsavailable/rewriteload/etc/apache2/modsenable/re
,将wwwmywebcom/connect跳转到connectmywebcomrewrite^/connect$http://connectmywebcompermanent;rewrite^/co
URLRewrite需要服务器的支持!在启用此设置之前,请确保服务器上已作出了正确的设置,设置方法请参看下边的“Apache下的设置方法”和“IIS下的设置方法”!Apache下的设置方法代码如下:打
URL定向知识点定向指令:redirect路由别名:alias实战演习Aboutvuerouter/indexjsAppvueAboutvue<template><div>