请选择 进入手机版 | 继续访问电脑版
查看: 615|回复: 0

nginx secure_link高级防盗链

[复制链接]

28

主题

29

帖子

172

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
172
发表于 2019-9-5 11:05:46 | 显示全部楼层 |阅读模式
下载服务器上有众多的软件资源, 可是很多来源不是本站,是迅雷、flashget, 源源不断的带宽,防盗链绝对是当务之急. 使用来源判断根本不靠谱,只能防止一些小白站点的盗链,迅雷之类的下载工具完全无效,如果你是nginx的话,使用secure link完美解决这个问题,远离迅雷.本文仅用于下载服务器,不适用于图片、视频防盗链.
1. 安装nginx
默认情况下nginx不会安装secure_link模块,需要手动指定,配置参数如下(见http://www.juwubox.com/forum.php?mod=viewthread&tid=26https://bugxia.com/308.html
  1. --prefix=/usr/local/nginx-1.4.2 --with-http_stub_status_module
复制代码
2. 配置nginx:
  1. server {

  2.     listen       80;
  3.     server_name  s1.down.ttlsa.com;
  4.     access_log  /data/logs/nginx/s1.down.ttlsa.com.access.log  main;

  5.     index index.html index.php index.html;
  6.     root /data/site/s1.down.ttlsa.com;

  7.     location / {
  8.         secure_link $arg_st,$arg_e;
  9.         secure_link_md5 ttlsa.com$uri$arg_e;

  10.         if ($secure_link = "") {
  11.             return 403;
  12.         }

  13.         if ($secure_link = "0") {
  14.             return 403;
  15.         }
  16.     }
  17. }
复制代码
3. php下载页面
  1. <?php
  2. $secret = 'ttlsa.com'; # 密钥
  3. $path = '/web/nginx-1.4.2.tar.gz'; # 下载文件
  4. # 下载到期时间,time是当前时间,300表示300秒,也就是说从现在到300秒之内文件不过期
  5. $expire = time()+300;
  6. # 用文件路径、密钥、过期时间生成加密串
  7. $md5 = base64_encode(md5($secret . $path . $expire, true));
  8. $md5 = strtr($md5, '+/', '-_');
  9. $md5 = str_replace('=', '', $md5);
  10. # 加密后的下载地址
  11. echo '<a href=http://s1.down.aaa.com/web/nginx-1.4.2.tar.gz?st='.$md5.'&e='.$expire.'>nginx-1.4.2</a>';
  12. echo '<br>http://s1.down.aaa.com/web/nginx-1.4.2.tar.gz?st='.$md5.'&e='.$expire;
  13. ?>
复制代码
4.  测试nginx防盗链
打开http://test.aaa.com/down.php点击上面的连接下载 下载地址如下:

http://s1.down.aaa.com/web/nginx ... eK3E8Q&e=1378881984

页面不要刷新,等到5分钟后在下载一次,你会发现点击下载会跳转到403页面。

5.  secure link 防盗链原理
用户访问down.php
down.php根据secret密钥、过期时间、文件uri生成加密串
将加密串与过期时间作为参数跟到文件下载地址的后面
nginx下载服务器接收到了过期时间,也使用过期时间、配置里密钥、文件uri生成加密串
将用户传进来的加密串与自己生成的加密串进行对比,一致允许下载,不一致403
整个过程实际上很简单,类似于用户密码验证. 尤为注意的一点是大家一定不要泄露了自己的密钥,否则别人就可以盗链了,除了泄露之外最好能经常更新密钥.

6.  secure link 指令
secure_link 语法: secure_link md5_hash[,expiration_time] 默认: none 配置段: location variables: yes

这个指令由uri中的MD5哈希值和过期时间组成. md5哈希必须由base64加密的,过期时间为unix时间.如果不加过期时间,那么这个连接永远都不会过期.

secure_link_md5 语法: secure_link_md5 secret_token_concatenated_with_protected_uri 默认: none 配置段: location variables: yes md5值对比结果,使用上面提供的uri、密钥、过期时间生成md5哈希值.如果它生成的md5哈希值与用户提交过来的哈希值一致,那么这个变量的值为1,否则为0

secure_link_secret 语法:     secure_link_secret word 默认: 配置段:     location Reference:    secure_link_secret nginx 0.8.50之后的版本已经使用secure_link_md5取代,不在多说.

7. 注意事项
密钥防止泄露、以及经常更新密钥
下载服务器和php服务器的时间不能相差太大,否则容易出现文件一直都是过期状态.
8.  最后
secure link以及内置到了nginx,不需要额外安装第三方模块,有下载服务器的兄弟,我极力推荐你们使用它,除非你不在乎你的带宽.



回复

使用道具 举报

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

本版积分规则

站长统计
快速回复 返回顶部 返回列表