码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Nginx】Nginx实现图片防盗链


    目录

    Nginx有三种方法可以进行防盗链

    1、对Nginx下所有项目的指定资源不同文件类型进行防盗链

    2、对指定目录或者指定项目目录进行防盗链

    3、nginx 的第三方模块ngx_http_accesskey_module 来实现下载文件的防盗链

    1. 对Nginx下所有项目的指定资源不同文件类型进行防盗链

    2. 对指定目录或者指定项目目录进行防盗链

    参考资料


    Nginx有三种方法可以进行防盗链

    1、对Nginx下所有项目的指定资源不同文件类型进行防盗链

    比如对gif、jpg、png、swf、flv、mp3、mp4等资源进行防盗链

    2、对指定目录或者指定项目目录进行防盗链

    比如Nginx下有3个项目,A、B、C,

    可以对A目录下的images进行防盗链,

    也可以对B目录下的images进行防盗链,

    也就是说,对指定目录进行防盗链。

    3、nginx 的第三方模块ngx_http_accesskey_module 来实现下载文件的防盗链

    1. 对Nginx下所有项目的指定资源不同文件类型进行防盗链

    找到nginx的配置文件nginx.conf:/usr/local/nginx/conf/nginx.conf

    1. http{
    2. ...
    3. server{
    4. location ~* \.(gif|jpg|png|swf|flv)$ { #需要防盗链资源的文件类型
    5. valid_referers none blocked 27wy.cn; #这是可以盗链的域名或IP地址,一般情况可以把google,baidu,sogou,soso,bing,feedsky,zhuaxia,photozero等域名放进来
    6. if ($invalid_referer) {
    7. #这样设置能够防盗链,不断地302重定向很多次,可能会加重服务器的负担,所以不建议这么做,除非有单独的图片服务器支持
    8. #rewrite ^/ https://www.27wy.cn:90/picture/images/details-image-1.jpg; #如果有人非法盗链资源,则返回一张防盗链的图片
    9. return 403; #或者返回403错误代码
    10. }
    11. }
    12. }
    13. }

    配置完成之后,重启nginx,重启命令:/usr/local/nginx/sbin/nginx -s reload

    2. 对指定目录或者指定项目目录进行防盗链

    1. location ~* /picture/images/{
    2. #在html目录下的picture项目下的images目录进行防盗链
    3. valid_referers none blocked server_names 27wy.cn;#允许访问目录的域名或IP
    4. if ($invalid_referer){
    5. return 403;
    6. }
    7. #不允许访问返回403
    8. }

     
    location [ = | ~ | ~* | ^~ ] uri {
    }
    #1.  =:用于不含正则表达式的uri前,要求请求字符串与uri严格匹配,若成功则停止搜索并立即处理该请求
    #2.  ~:用于表示uri的正则表达式,并且区分大小写
    #3.  ~*:用于表示uri的正则表达式,并且不区分大小写
    #4.  ^~:用于不含正则表达式的uri前, 找到匹配度最高的location后,立即处理请求,不再做uri中的正则匹配
    #注意:若是uri中包含正则表达式,则必须有~或者~*标识

    参考资料

    32-基本使用-防盗链与http的referer_哔哩哔哩_bilibili

    CDN常用的防盗链是什么?有什么作用?_jack_ja的博客-CSDN博客_cdn防盗链

    今天我们来聊聊防盗链机制_lakernote的博客-CSDN博客_防盗链机制

    配置nginx实现防盗链功能_BK_小小关的博客-CSDN博客_nginx防盗链配置

    nginx防盗链教程 nginx图片防盗链详细解说 - shuaixf - 博客园

    16《Nginx 入门教程》Nginx防盗链配置 - 知乎

    Nginx怎么搭建文件防盗链服务 - 大数据 - 亿速云

    【初探篇】Nginx配置防盗链(详细了解如何配置nginx防盗链)_不知名架构师的博客-CSDN博客_nginx配置防盗链

    防盗链时需要注意搜索引擎 Referer,百度和 Google 搜索内容跳转链接之间的区别 - 左小白的技术日常 

  • 相关阅读:
    利用MySQL主从复制延迟拯救误删数据
    配电室数据中心巡检3d可视化搭建的详细步骤
    运动式蓝牙耳机哪个牌子好?运动式蓝牙耳机品牌推荐
    LeetCode二叉树系列——94.二叉树的中序遍历
    数字信号采集保存与处理通用过程
    ESP8266-Arduino编程实例-TTP223 电容式触摸传感器驱动
    2023-09-04 Linux 让shell编译脚本里面设置的环境变量改变kernel里面驱动文件的宏定义值方法,我这里用来做修改固件版本
    【java-Date】
    Linux中使用nfs共享存储
    2024年高新技术企业认定标准
  • 原文地址:https://blog.csdn.net/luomao2012/article/details/126760196
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号