• NGINX 如何防盗链


    一、安装Nginx:

    1、解决依赖关系

    # yum groupinstall "Development Tools" "Server Platform Deveopment"
    # yum install openssl-devel pcre-devel

    2、安装
    首先添加用户nginx,实现以之运行nginx服务进程:

    # groupadd -r nginx
    # useradd -r -g nginx nginx
    接着开始编译和安装:
    # ./configure 
      --prefix=/usr 
      --sbin-path=/usr/sbin/nginx 
      --conf-path=/etc/nginx/nginx.conf 
      --error-log-path=/var/log/nginx/error.log 
      --http-log-path=/var/log/nginx/access.log 
      --pid-path=/var/run/nginx/nginx.pid  
      --lock-path=/var/lock/nginx.lock 
      --user=nginx 
      --group=nginx 
      --with-http_ssl_module 
      --with-http_flv_module 
      --with-http_stub_status_module 
      --with-http_gzip_static_module 
      --http-client-body-temp-path=/var/tmp/nginx/client/ 
      --http-proxy-temp-path=/var/tmp/nginx/proxy/ 
      --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ 
      --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi 
      --http-scgi-temp-path=/var/tmp/nginx/scgi 
      --with-pcre
    # make && make install

    说明:
    1、Nginx可以使用Tmalloc(快速、多线程的malloc库及优秀性能分析工具)来加速内存分配,使用此功能需要事先安装gperftools,而后在编译nginx添加--with-google_perftools_module选项即可。
    2、 如果想使用nginx的perl模块,可以通过为configure脚本添加--with-http_perl_module选项来实现,但目前此模块仍 处于实验性使用阶段,可能会在运行中出现意外,因此,其实现方式这里不再介绍。如果想使用基于nginx的cgi功能,也可以基于FCGI来实现,具体实 现方法请参照网上的文档。

    3、为nginx提供SysV init脚本:

    新建文件/etc/rc.d/init.d/nginx,内容如下:

    #!/bin/sh
    #
    # nginx - this script starts and stops the nginx daemon
    #
    # chkconfig:   - 85 15
    # description:  Nginx is an HTTP(S) server, HTTP(S) reverse 
    #               proxy and IMAP/POP3 proxy server
    # processname: nginx
    # config:      /etc/nginx/nginx.conf
    # config:      /etc/sysconfig/nginx
    # pidfile:     /var/run/nginx.pid
    # Source function library.
    . /etc/rc.d/init.d/functions
    # Source networking configuration.
    . /etc/sysconfig/network
    # Check that networking is up.
    [ "$NETWORKING" = "no" ] && exit 0
    nginx="/usr/sbin/nginx"
    prog=$(basename $nginx)
    NGINX_CONF_FILE="/etc/nginx/nginx.conf"
    [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
    lockfile=/var/lock/subsys/nginx
    make_dirs() {
       # make required directories
       user=`nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=([^ ]*).*/1/g' -`
       options=`$nginx -V 2>&1 | grep 'configure arguments:'`
       for opt in $options; do
           if [ `echo $opt | grep '.*-temp-path'` ]; then
               value=`echo $opt | cut -d "=" -f 2`
               if [ ! -d "$value" ]; then
                   # echo "creating" $value
                   mkdir -p $value && chown -R $user $value
               fi
           fi
       done
    }
    start() {
        [ -x $nginx ] || exit 5
        [ -f $NGINX_CONF_FILE ] || exit 6
        make_dirs
        echo -n $"Starting $prog: "
        daemon $nginx -c $NGINX_CONF_FILE
        retval=$?
        echo
        [ $retval -eq 0 ] && touch $lockfile
        return $retval
    }
    stop() {
        echo -n $"Stopping $prog: "
        killproc $prog -QUIT
        retval=$?
        echo
        [ $retval -eq 0 ] && rm -f $lockfile
        return $retval
    }
    restart() {
        configtest || return $?
        stop
        sleep 1
        start
    }
    reload() {
        configtest || return $?
        echo -n $"Reloading $prog: "
        killproc $nginx -HUP
        RETVAL=$?
        echo
    }
    force_reload() {
        restart
    }
    configtest() {
      $nginx -t -c $NGINX_CONF_FILE
    }
    rh_status() {
        status $prog
    }
    rh_status_q() {
        rh_status >/dev/null 2>&1
    }
    case "$1" in
        start)
            rh_status_q && exit 0
            $1
            ;;
        stop)
            rh_status_q || exit 0
            $1
            ;;
        restart|configtest)
            $1
            ;;
        reload)
            rh_status_q || exit 7
            $1
            ;;
        force-reload)
            force_reload
            ;;
        status)
            rh_status
            ;;
        condrestart|try-restart)
            rh_status_q || exit 0
                ;;
        *)
            echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
            exit 2
    esac

    而后为此脚本赋予执行权限:
    # chmod +x /etc/rc.d/init.d/nginx

    添加至服务管理列表,并让其开机自动启动:
    # chkconfig --add nginx
    # chkconfig nginx on

    而后就可以启动服务并测试了:
    # service nginx start

    Nginx 的代码是由一个核心和一系列的模块组成, 核心主要用于提供Web Server的基本功能,以及Web和Mail反向代理的功能;还用于启用网络协议,创建必要的运行时环境以及确保不同的模块之间平滑地进行交互。不过, 大多跟协议相关的功能和某应用特有的功能都是由nginx的模块实现的。这些功能模块大致可以分为事件模块、阶段性处理器、输出过滤器、变量处理器、协 议、upstream和负载均衡几个类别,这些共同组成了nginx的http功能。事件模块主要用于提供OS独立的(不同操作系统的事件机制有所不同) 事件通知机制如kqueue或epoll等。协议模块则负责实现nginx通过http、tls/ssl、smtp、pop3以及imap与对应的客户端 建立会话。

    Nginx的核心模块为Main和Events,此外还包括标准HTTP模块、可选HTTP模块和邮件模块,其还可以支持诸多 第三方模块。Main用于配置错误日志、进程及权限等相关的参数,Events用于配置IO模型,如epoll、kqueue、select或poll 等,它们是必备模块。

     3防盗链
    (1) 定义合规的引用
    valid_referers none | blocked | server_names | string ...;
    (2) 拒绝不合规的引用
    if  ($invalid_referer) {
    rewrite ^/.*$ http://www.b.org/403.html
    }

    valid_referers

    语法:valid_referers [none|blocked|server_names] … 
    默认值:no 
    使用字段:server, location 
    这个指令在referer头的基础上为 $invalid_referer 变量赋值,其值为0或1。
    可以使用这个指令来实现防盗链功能,如果valid_referers列表中没有Referer头的值, $invalid_referer将被设置为1(参照前例)。
    参数可以使如下形式:

      • none意为不存在的Referer头
      • blocked意为根据防火墙伪装Referer头,如:“Referer: XXXXXXX”。
      • server_names为一个或多个服务器的列表,0.5.33版本以后可以在名称中使用“*”通配符。
    server {
            listen       80;
            server_name  www.baidu.org;
            #charset koi8-r;
            #access_log  logs/host.access.log  main;
            location / {
                root   /www/baidu.org/;
                index  index.html index.htm;
            }
    
    ############################################################### 如下:防盗链
            location ~* .(jpg|png|gif|jpeg)$ {
                root /www/baidu.org;
                valid_referers none blocked www.baidu.org *.baidu.org; 
                if ($invalid_referer) {
                    rewrite ^/ http://www.baidu.org/403.html; # 如果有盗链的情况就使用url重写到错我页面
                }
            }
    }
    [root@node5 nginx]# cd /www/baidu.org/
    [root@node5 baidu.org]# pwd
    /www/baidu.org
    [root@node5 baidu.org]# cat index.html
    www.baidu.org
    <img src="http://172.16.249.27/images/1.jpg">
    #####################自己域内中的服务器使用####################
    [root@node5 baidu.org]# cd /www/firefox.com/
    [root@node5 firefox.com]# cat index.html
    <h1>www.firefox.com<h1>
    <img src="http://172.16.249.27/images/1.jpg">
    ####################不是属于本区域内的服务器###################

    wKioL1NadaDiis4zAAdJYOzFm44188.jpg

    wKiom1NaddvQdNQOAACy1ekAAh4222.jpg

  • 相关阅读:
    Work harder, smarter 工作需要努力和智慧
    且慢下手(转)
    .net 打包中的参数传递
    sql语句编写技巧
    在安装文件中解压sfx压缩文件
    vs.net编程技巧
    統制勘定(reconciliationaccounts)とは
    ExtJs页面布局总结(转载)
    ext自定义form表单参数为JSON格式getJsonValue:(同时提交多个表单时需要用到)
    oracle截取日期函数
  • 原文地址:https://www.cnblogs.com/xiaocen/p/3719655.html
Copyright © 2020-2023  润新知