1:指定rewrite规则
rewrite regex replacement [flag];
 
什么是rewrite规则:If the specified regular expression matches a request URI, URI is changed as specified in the replacement string. The rewrite directives are executed sequentially in order of their appearance in the configuration file. It is possible to terminate further processing of the directives using flags. If a replacement string starts with “http://”, “https://”, or “$scheme”, the processing stops and the redirect is returned to a client.
 
欢哥人工翻译(可以打赏哦!!!):如果regex匹配到用户访问的URI,那么用户访问的URI就会被替换为replacement所指定的string。这个replacement所指定的string会继续向后执行,但是执行到哪里结束会给flags这个参数所决定。如果这个replacement是“http://”, “https://”, 或者是“$scheme”开头的话,那么rewrite将不会向后执行,会直接终止并返回给客户端
 
rewrite的工作法则:
1:rewrite实现重写操作,匹配URI可以使用正则表达式匹配,替换可以使用正则表达式的后向引用
2:如果在location中存在多个rewrite规则会自上而下逐个被匹配检查,可以使用flag参数控制
3:如果replacement string是以“http://”, “https://”, 或者是“$scheme”开头的话,则替换结果会直接以重定向方式返回给用户
 
flag参数详解:
1:last:表示结束本轮rewrite规则从上之下进行检查,而是从最开始从新循环检查,且请求结果不会返回给客户端(状态码为:200)
2:break:重写完成后不会对将前URI进行后续的匹配检查,直接将URI请求的资源返回给客户端(状态码为:200)
3:redirect:重定向完成后以临时重定向的方式直接返回新的URL给客户端,客户端再对新的URL发起请求(状态码为:302)
4:permanent:重定向成后以永久重定向的方式直接返回新的URL给客户端,客户端在对新的URL发起请求(状态码为:301)
 
避免死循环匹配:(加一个break)
location / {
root /app;
index index.html index.htm;
rewrite (.*)\.htm$ $1.html break;
}
 
location ~* \.html$ {
root /app;
index index.html index.htm;
rewrite (.*)\.html$ $1.htm break;
}
 
 
2:指定rewrite是否记录到日志,如果启用,这些rewrite日志会记录到错误日志中
rewrite_log on | off;
 
3:设置条件判断,如果条件满足,执行指定的指令
判断表达式:
==:精确等于
!=:不等于
~:模式匹配,区分字母大小写
~*:模式匹配,不区分字母大小写
!~:模式不匹配,区分字母大小写
!~*:模式不匹配,不区分字母大小写
 
检查file或directory的属性:
-f, !-f:如果文件存在
-d, !-d: 如果目录存在
-e, !-e:如果文件或目录或链接存在
-x , !-x:如果文件可执行
 
例如:
if ($http_user_agent ~ MSIE) {
rewrite ^(.*)$ /msie/$1 break;
}
 
if ($http_cookie ~* "id=([^;]+)(?:;|$)") {
set $id $1;
}
 
if ($request_method = POST) {
return 405;
}
 
if ($slow) {
limit_rate 10k;
}
 
if ($invalid_referer) {
return 403;
}
 
4:自定义变量
set $variable value
 
例如:
set $hello "ni hao"
 
5:指定返回的状态码或URL,停止处理URI匹配过程
return code
 
例如:
if ($invalid_referer) {
return 403 "<p> wrong page </p>"
}
  • ngx_http_gzip_module(压缩)
功用:用户压缩文本资源
 
1:启用gzip压缩功能
gzip on | off;
 
2:指定压缩比例,1-9,默认为1
gzip_comp_level level;
 
3:开启压缩功能的最小的长度
gzip_min_length length;
 
4:设定协议的最小版本以上都可以压缩
gzip_http_version 1.0 | 1.1;
 
5:设定压缩的资源内容类型,默认为text/html
gzip_types mime-type …;
 
 
6:如果Nginx是方向代理如果进行压缩
gzip_proxied off | expired | no-cache | no-store | private | no_last_modified | no_etag | auth | any …;
 
例如:
gzip on
gzip_http_version 1.1
gzip_disable msle6
gzip_min_lengh 1000
gzip_types text/plain text/css text/js application/xml
gzip_proxied expired no-cache no-store private auth;
  • ngx_http_fastcgi_module(fastcgi功能)
对于LAMP来说:实现fastcgi协议的模块为proxy_fastcgi_module,
对于LNMP来说:实现fastcgi协议的模块为ngx_http_fastcgi_module,
 
fastcgi模块的指令说明:
 
 
1:在Nginx中指定php-fpm服务器监听的地址和端口
fastcgi_pass address;
例如:fastcgi_pass 127.0.0.1:9000;
 
2:定义fastcgi应用的主页名称
fastcgi_index name;
例如:fastcgi_index index.php;
 
3:传递给php-fpm服务器参数及其值
fastcgi_param parameter value [if_not_empty];
例如:fastcgi_param SCRIPT_FILENAME /apps/php/$fastcgi_script_name;
需要导入fastcgi_param参数文件,用include fastcgi_params; 这个 fastcgi_param文件里面有各种的变量,其中就有$fastcgi_script_name。
 
 
4:fastcgi_cache_path path [levels=levels] [use_temp_path=on|off] keys_zone=name:size [inactive=time] [max_size=size] [manager_files=number] [manager_sleep=time] [manager_threshold=time] [loader_files=number] [loader_sleep=time] [loader_threshold=time] [purger=on|off] [purger_files=number] [purger_sleep=time] [purger_threshold=time];
 
path:指明缓存文件系统路径,用于缓存文件数据,在这个路径下会有n级结构,实现对文件数据的快速查找,使用的hash算法
 
max_size=size:此路径下指定多大的空间用于缓存数据
 
levels=#:指定缓存目录的层级结构
例如:levels=1:2 表示:一级目录的名称为1个字符,二级目录的名称为2个字符
 
keys_zone=name:size:指定磁盘上用于存储value的存储空间名称、大小
 
inactive=time:指定非活动时间
 
max_size=size:指定存储的空间大小
 
注意:这个只能用于http上下文(/var/cache/nginx_fastcgi目录需要先创建好)
例如:在http的上下文中指定:fastcgi_cache_path /var/cache/nginx_fastcgi levels=1:2:3 keys_zone=fcgi_cache:10m inactive=3h;
在一个fastcgi的location中调用这个fastcgi_cache存储空间名
例如:
location ~ \.php$ {
fastcgi_cache fcgi_cache;
}
 
 
5:是否启用cache功能,如何启用,数据缓存在哪个cache中
fastcgi_cache zone | off;
例如:在使用fastcgi的location中添加:fastcgi_cache fcgicache; 指明调用的缓存的名字
 
6:指明在缓存中使用什么作为k/v键值对中的key
fastcgi_cache_key string;
例如:在使用fastcgi的location中添加:fastcgi_cache_key $request_uri; 指明以用户请求的uri为key
 
 
7:指明缓存哪些请求方法的数据
fastcgi_cache_methods GET | HEAD | POST …;
例如:fastcgi_cache_methods GET
 
8:指定请求匹配的最小次数,大于最小次数才会缓存
fastcgi_cache_min_uses number;
例如:fastcgi_cache_min_uses 5;
 
9:指明对应的响应码缓存的时间,没有定义是不会缓存的
fastcgi_cache_valid [code …] time;
例如:
fastcgi_cache_valid 200 30s;
fastcgi_cache_valid 301 302 1m;
fastcgi_cache_valid any 10s;
 
注意:用使用缓存机制,需要在location中指定如下三个指令
fastcgi_cache
fastcgi_cache_key
fastcgi_cache_valid
 
 
 
 
在Nginx中使用ngx_http_fastcgi_module示例
location ~ \.php$ {
# 将客户端请求的URI从$fastcgi_script_name变量中取出来,且通过fastcgi发送给php服务器,fastcgi://192.168.23.201:9000/apps/php/$fastcgi_script_name。那么PHP服务器就会在本地的文件系统去找/apps/php/$fastcgi_script_name资源。
fastcgi_pass 192.168.23.201:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /apps/php/$fastcgi_script_name;
include fastcgi_params;
# 指明缓存的键,这里存储的是key值
fastcgi_cache_key $request_uri;
# 调用缓存的磁盘存储空间,这里存储的是value值
fastcgi_cache fcgi_cache;
# 指定可以缓存的状态码
fastcgi_cache_valid 200 30s;
fastcgi_cache_valid 301 302 1m;
fastcgi_cache_valid any 10s;
}

ngx_http_rewrite_module(重定向)的更多相关文章

  1. Nginx常用模块及作用

    Nginx模块详解 nginx模块分为两种,官方和第三方,我们通过命令 nginx -V 查看 nginx已经安装的模块! [root@localhost ~]# nginx -V nginx ver ...

  2. Nginx 之四: Nginx服务器的rewrite、全局变量、重定向和防盗链相关功能

    一:Nginx 后端服务器组的配置: 1.upstream: 用于设置后端服务器组的主要指令,upstream类似于之前的server块或http块,用法如下: upstreame Myserver{ ...

  3. Nginx服务器的rewrite、全局变量、重定向和防盗链相关功能

    一:Nginx 后端服务器组的配置: 1.upstream: 用于设置后端服务器组的主要指令,upstream类似于之前的server块或http块,用法如下: upstreame Myserver{ ...

  4. Nginx 模块 - ngx_http_rewrite_module

    原文地址 ngx_http_rewrite_module 模块用于通过 PCRE 正则表达式改变请求 URI,返回重定向并可以有条件地选择配置. break.if.return.rewrite 以及 ...

  5. Nginx Rewrite资源重定向

    # Rewrite功能配置 # Rewrite功能主要是实现了url重写 # 如:你输入www.jd123.com,你可以通过Rewrite让它重定向到www.jd.com # Rewrite的实现依 ...

  6. Http状态码之:301、302重定向

    概念 301 Moved Permanently 被请求的资源已永久移动到新位置,并且将来任何对此资源的引用都应该使用本响应返回的若干个URI之一.如果可能,拥有链接编辑功能的客户端应当自动把请求的地 ...

  7. 前端学HTTP之重定向和负载均衡

    前面的话 HTTP并不是独自运行在网上的.很多协议都会在HTTP报文的传输过程中对其数据进行管理.HTTP只关心旅程的端点(发送者和接收者),但在包含有镜像服务器.Web代理和缓存的网络世界中,HTT ...

  8. Web安全相关(三):开放重定向(Open Redirection)

    简介 那些通过请求(如查询字符串和表单数据)指定重定向URL的Web程序可能会被篡改,而把用户重定向到外部的恶意URL.这种篡改就被称为开发重定向攻击.   场景分析 假设有一个正规网站http:// ...

  9. Spring MVC重定向和转发以及异常处理

    SpringMVC核心技术---转发和重定向 当处理器对请求处理完毕后,向其他资源进行跳转时,有两种跳转方式:请求转发与重定向.而根据要跳转的资源类型,又可分为两类:跳转到页面与跳转到其他处理器.对于 ...

随机推荐

  1. Field Security Profile Helper

    using System; using Microsoft.Xrm.Sdk; using Microsoft.Xrm.Sdk.Messages; /// <summary> /// 安全字 ...

  2. Linux下更新git版本

    查看git版本,卸载旧版本(如果没有安装git请直接到下一步) git --version yum remove git 安装依赖软件 yum install curl-devel expat-dev ...

  3. python 验证码识别初探

    使用 pytesser 与 pytesseract 识别验证码 前置 :  首先需要安装  tesserract tesserract windows 安装包及中文 https://pan.baidu ...

  4. postgres-xl 安装与部署 【异常处理】ERROR: could not open file (null)/STDIN_***_0 for write, No such file or directory

    https://www.jianshu.com/p/82aaf352b772 这篇文章很不错,里面有个bug,可能是版本不对. 当前(2018-04-11)通过git 下载原代码时,在配置  pgxc ...

  5. EntityFramework6.1自动生成复数名称数据表的问题

    遇到一个很奇怪的问题,两个程序部署在两个不同的机器上,一个是.net 4.6.1另外一个是.net 4.0的运行时,两个项目都引用了EntityFramework6.1.3.程序分别执行后,4.0环境 ...

  6. 关于正则表达式"\b"

    今天刚刚开始看正则表达式就遇到一个十分头疼的问题,原文是这样的: “不幸的是,很多单词里包含hi这两个连续的字符,比如him,history,high等等.用hi来查找的话,这里边的hi也会被找出来. ...

  7. ubuntu装openVPN会遇到的问题

    与Windows系统相比,Linux下安装OpenVPN的过程就显得有点曲折. 如果你使用的是Ubuntu系统,你可以直接使用命令sudo apt-get install -y openvpn来安装O ...

  8. 【LG4587】[FJOI2016]神秘数

    [LG4587][FJOI2016]神秘数 题面 洛谷 题解 首先我们想一想暴力怎么做 对于一段区间\([l,r]\) 我们先将它之间的数升序排序 从左往右扫, 设当前我们可以表示出的数为\([1,x ...

  9. 详解UML图之类图

    产品经理的必备技能之一是画UML图,本文就告诉你怎么画标准的类图吧.本文结合网络资料和个人心得所成,不当之处,请多指教. 1.为什么需要类图?类图的作用 我们做项目的需求分析,最开始往往得到的是一堆文 ...

  10. 【mysql经典题目】行转列

    参考:http://www.cnblogs.com/h07061108/p/mysql_questions.html#3806338 实现如下效果 CREATE TABLE IF NOT EXISTS ...