Nginx——基本语法简介(初级篇)

2012-8-10 15:55:58 来源:本站原创,请勿转载 浏览:3312
Nginx是一款十分轻量级的HTTP服务器,同时也是反向代理、IMAP/POP3/SMTP代理服务器,很适合编程人士们的使用。本文主要是针对Nginx新手们向大家介绍一下Nginx的一些常用的基本语法的使用,比如防盗链的设置、重定向、重写语句的写法等等。建议用护卫神·主机大师(Nginx版)搭建网站环境

护卫神·主机大师(Nginx版),是一款专业搭建Nginx平台的网站环境搭建工具,可以搭建Nginx+多版本PHP+MySQL+FTP+PhpMyAdmin等,详情请点击>>


前面我们像大家介绍一下Nginx的安装步骤及配置文件等等,今天我们将会问大家介绍一下有关Nginx的一些常用语法及其用法,请看下文……

一、Redirect语法简介及用法:

Redirect学过编程的朋友们应该都知道是是重定向的意思,具体在nginx中Redirect的语法规则是怎样的呢,贴一段代码供参考:

server {
    listen 80;
    server_name start.igrow.cn;
    index index.html index.php;
    root html;
    if ($http_host !~ '^star\.igrow\.cn$&quot [点击图片可在新窗口打开] {
         rewrite ^(.*) http://star.igrow.cn$1 redirect;
    }
    }

二、ReWrite语法语法的介绍及用法:

ReWrite也就是重写的意思,在编程中也是一个十分重要的语法。

1、ReWrite语法中几个常用的句型:

last - 基本上都用这个Flag。
break - 中止Rewirte,不在继续匹配
redirect - 返回临时重定向的HTTP状态302
permanent - 返回永久重定向的HTTP状态301

2、ReWrite表达式中可以表示判断的表达式:

-f和!-f用来判断是否存在文件
-d和!-d用来判断是否存在目录
-e和!-e用来判断是否存在文件或目录
-x和!-x用来判断文件是否可执行

3、ReWrite表达式中可以用作判断的全局变量,示例如下:

例:http://localhost:88/test1/test2/test.php
$host:localhost
$server_port:88
$request_uri:http://localhost:88/test1/test2/test.php
$document_uri:/test1/test2/test.php
$document_root:D:\nginx/html
$request_filename:D:\nginx/html/test1/test2/test.php

三、Location语法简介及其用法:

例:location [=|~|~*|^~] /uri/ { … }

1、 Location语法语句中常用表达示的含义:

    1)~   区分大小写匹配
    2)~* 不区分大小写匹配
    3)!~和!~* 分别为区分大小写不匹配及不区分大小写不匹配

2、几个使用实例:

   1)location  / { }:匹配任何查询,因为所有请求都以 / 开头。但是正则表达式规则将被优先和查询匹配。
   2)location =/ {}:仅仅匹配/
   3)location ~* \.(gif|jpg|jpeg)$

     {
        rewrite \.(gif|jpg)$ /logo.png;
     }

小提示:如果location不区分大小写的话乐意匹配任何以gif,jpg,jpeg结尾的文件。

四、设置某文件类型的过期时间:

Nginx还可以自定义某一类型的文件的保质期时间,具体写法看下文的代码:

location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ {
if (-f $request_filename) {
   expires    1h;
   break;
  }
  }

//上段代码就将js|css|jpg|jpeg|gif|png|swf这类文件的保质期设置为一小时。

五、设置权限-禁止访问某目录:

为了使服务器更加安全,Nginx支持用户自行定义目录的权限,如果你想禁止所有人访问到你的某个目录的话,具体代码如下:

location ~* \.(txt|doc)${
      root /data/www/wwwroot/linuxtone/test;
     deny all;
    }

// deny all;就表示禁止所有人访问上面的那个目录

六、防盗链的设置:

防盗链:如果你的网站是个下载网站,下载步骤应该是先经过你的主页找到下载地址,才能下载,为了防止某些网友直接访问下载地址完全不通过主页下载,我们就可以使用防盗链的方式,具体代码如下:

location ~* \.(gif|jpg|swf)$ {
  valid_referers none blocked start.igrow.cn sta.igrow.cn;
  if ($invalid_referer) {
  rewrite ^/ http://$host/logo.png;
  }
}

上文就对Nginx的基本常用的语法进行了一些简单的介绍,如果各位大虾们还有其他的问题,欢迎留言。

如需要nginx软件的下载,护卫神下载频道提供下载,请点击选择nginx版本。

(0)
(0)