网站之家技术交流论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1705|回复: 0

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

[复制链接]
发表于 2013-5-24 04:32:15 | 显示全部楼层 |阅读模式
Nginx是一款十分轻量级的HTTP服务器,同时也是反向代理、IMAP/POP3/SMTP代理服务器,很适合编程人士们的使用。本文主要是针对Nginx新手们向大家介绍一下Nginx的一些常用的基本语法的使用,比如防盗链的设置、重定向、重写语句的写法等等。

前面我们像大家介绍一下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$" [点击图片可在新窗口打开] {
         rewrite ^(.*) http://www.web49.com$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的基本常用的语法进行了一些简单的介绍,如果各位大虾们还有其他的问题,欢迎留言。

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|网站之家技术交流论坛 ( 粤ICP备09092995号 )

GMT+8, 2024-12-22 18:48 , Processed in 0.097794 second(s), 7 queries , File On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表