当前位置: 首页 > article >正文

【Nginx】Nginx防盗链的配置详解

前情提要本篇博客详细介绍了防盗链以及配置盗链盗取网站资源和配置防盗链防止别人盗取两种示例通过本篇博客你可以学会利用nginx配置盗链和防盗链环境清单真实服务主机172.25.254.10/24盗链主机172.25.254.11/24一、Nginx防盗链简介防盗链基于客户端携带的referer实现referer是记录打开一个页面之前记录是从哪个页面跳转过来的标记信息如果别人只链接了自己网站图片或某个单独的资源而不是打开了网站的整个页面这就是盗链referer就是之前的那个网站域名正常的referer信息有以下几种none #请求报文首部没有referer首部 #比如用户直接在浏览器输入域名访问web网站就没有referer信息。 blocked #请求报文有referer首部但无有效值比如为空。 server_names #referer首部中包含本主机名及即nginx 监听的server_name。 arbitrary_string #自定义指定字符串但可使用*作通配符。示例: *.timinglee.org www.timinglee.* regular expression #被指定的正则表达式模式匹配到的字符串,要使用~开头例如 ~.*\.timinglee\.com正常通过搜索引擎搜索web网站并访问该网站的referer信息如下172.25.254.1 - - [22/Jul/2024:09:27:36 0800] GET /favicon.ico HTTP/1.1 404 149 http://lee.timinglee.org/ Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/115.0 2024/07/22 09:27:36 [error] 34596#0: *205 open() /webdata/nginx/timinglee.org/lee/favicon.ico failed (2: No such file or directory), client: 172.25.254.1, server: lee.timinglee.org, request: GET /favicon.ico HTTP/1.1, host: lee.timinglee.org, referrer: http://lee.timinglee.org/二、实现盗链在一个web站点盗链另一个站点的资源信息比如:图片、视频等# 创建放盗链文件 [rootNginx ~]# mkdir /webdata/nginx/doubledragon.org/daolian [rootNginx ~]# mv daolian.png /webdata/nginx/doubledragon.org/daolian/ # 创建盗链文件 [rootNginx ~]# mv dragon.png /webdata/nginx/doubledragon.org/img/ # 在新的一台主机配置盗链 [rootNginx2 ~]# vim /var/www/html/index.html html head meta http-equivContent-Type contenttext/html;charsetutf-8 title盗链/title /head body img srchttp://www.doubledragon.org/img/dragon.png h1 stylecolor:red欢迎大家/h1 pa hrefhttp://www.doubledragon.org狂点dragon/a出门见喜/p /body /html访问测试可以看见如果没有防盗措施那么盗版网站可以直接使用我们的网站内的图片和资源等点击链接也可以直接跳转到我们的页面三、实现防盗链# 编辑nginx子配置文件 [rootNginx ~]# vim /usr/local/nginx/conf/conf.d/vhost.conf server { listen 80; server_name www.doubledragon.org; root /webdata/nginx/doubledragon.org; location / { valid_referers none blocked server_names *.doubledragon.org ~/.baidu/.; if ($invalid_referer){ return 404; } } location /img { valid_referers none blocked server_names *.doubledragon.org ~/.baidu/.; if ($invalid_referer){ rewrite ^/ http://www.doubledragon.org/daolian/daolian.png; } } } # 配置文件解析 # 第一段 valid_referers定义了哪些来源被认为是“合法”的。 none请求头中没有 Referer 字段例如直接在浏览器输入网址。 blockedReferer 字段存在但被防火墙或代理屏蔽了。 server_namesReferer 是本服务器配置的域名即 www.doubledragon.org。 *.doubledragon.org所有 doublerdragon.org 的子域名。 ~/.baidu/.正则匹配允许来自百度baidu的请求通常是为了让搜索引擎爬虫能正常抓取。 if ($invalid_referer)如果请求的来源不在上述白名单中即变量 $invalid_referer 为真则执行大括号内的操作。 return 404;直接返回 HTTP 404 错误页面。这意味着如果有人在别的网站引用了你网站上的普通文件非图片请求会被直接拒绝。 # 第二段 valid_referers这里的白名单规则与上面完全一致。 rewrite ^/ http://www.doubledragon.org/daolian/daolian.png; 当非法请求访问 /img 目录下的资源时不会返回 404 错误。 而是使用 rewrite 指令将请求重定向到一个特定的图片http://www.doubledragon.org/daolian/daolian.png。 实际效果如果其他网站盗链了你网站的图片他们网页上显示的将不再是他们想要的图片而是你指定的这张 daolian.png通常是一张“禁止盗链”或网站 Logo 的图片。可以看见盗版网站无法访问我们的图片资源了点击链接也会出现404

相关文章:

【Nginx】Nginx防盗链的配置详解

前情提要:本篇博客详细介绍了防盗链,以及配置盗链盗取网站资源和配置防盗链防止别人盗取两种示例,通过本篇博客你可以学会利用nginx配置盗链和防盗链环境清单真实服务主机:172.25.254.10/24盗链主机:172.25.254.11/24一…...

DeepSeek LeetCode 1425.带限制的子序列和 public int constrainedSubsetSum(int[] nums, int k)

以下是 LeetCode 1425「带限制的子序列和」的 Java 解法,使用动态规划 单调队列实现,时间复杂度 O(n),空间复杂度 O(n)。java public int constrainedSubsetSum(int[] nums, int k) {int n nums.length;int[] dp new int[n]; // …...

Phi-4-Reasoning-Vision快速部署:CI/CD自动化测试流水线搭建

Phi-4-Reasoning-Vision快速部署:CI/CD自动化测试流水线搭建 1. 项目概述 Phi-4-Reasoning-Vision是基于微软Phi-4-reasoning-vision-15B多模态大模型开发的高性能推理工具,专为双卡4090环境优化。这个工具严格遵循官方SYSTEM PROMPT规范,支…...

novelWriter国际化支持:如何为多语言写作优化设置

novelWriter国际化支持:如何为多语言写作优化设置 【免费下载链接】novelWriter novelWriter is an open source plain text editor designed for writing novels. 项目地址: https://gitcode.com/gh_mirrors/no/novelWriter novelWriter是一款专为小说创作设…...

AutoCAD字体管理终极指南:FontCenter自动解决字体缺失问题

AutoCAD字体管理终极指南:FontCenter自动解决字体缺失问题 【免费下载链接】FontCenter AutoCAD自动管理字体插件 项目地址: https://gitcode.com/gh_mirrors/fo/FontCenter 还在为AutoCAD图纸中的字体缺失而烦恼吗?😩 每次打开同事发…...

墨语灵犀创意写作效果PK:不同风格文案生成对比展示

墨语灵犀创意写作效果PK:不同风格文案生成对比展示 最近在试用各种AI写作工具,发现了一个挺有意思的现象:很多工具号称能写各种风格,但真用起来,要么风格不明显,要么写出来的东西总带着一股“AI味儿”。这…...

Laravel多租户安全防护完整手册:保护租户数据隔离与访问控制的终极指南

Laravel多租户安全防护完整手册:保护租户数据隔离与访问控制的终极指南 【免费下载链接】multi-tenant Run multiple websites using the same Laravel installation while keeping tenant specific data separated for fully independent multi-domain setups, pre…...

终极指南:如何用IPXWrapper在Windows 11上复活经典游戏局域网联机

终极指南:如何用IPXWrapper在Windows 11上复活经典游戏局域网联机 【免费下载链接】ipxwrapper 项目地址: https://gitcode.com/gh_mirrors/ip/ipxwrapper 还记得那些经典的《星际争霸》、《魔兽争霸2》、《暗黑破坏神》局域网对战时光吗?这些承…...

Shadow Robot 触觉传感器:摄像头隔着透明层,直接“看见”接触与形变

本文素材源于专利US12025525)一个触觉传感器包括以下组件:1. 第一层:由柔性材料形成,具有外部接触表面和相对的内部接口表面。2. 第二层:由基本透明的柔性材料形成,与第一层在接口表面处连续接触。3. 摄像头…...

安全与对齐:上下文工程在可信AI系统中的关键作用

安全与对齐:上下文工程在可信AI系统中的关键作用 【免费下载链接】Awesome-Context-Engineering 🔥 Comprehensive survey on Context Engineering: from prompt engineering to production-grade AI systems. hundreds of papers, frameworks, and imp…...

Qwen3.5-4B-Claude-Opus效果展示:Python回文函数生成+思路结构化呈现

Qwen3.5-4B-Claude-Opus效果展示:Python回文函数生成思路结构化呈现 1. 模型能力概览 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是一个专注于推理和结构化分析的轻量级AI模型。这个经过特殊训练的版本在以下方面表现出色: 分步骤推理&…...

AutoGLM-Phone-9B多模态功能体验:图像识别与语音处理实战演示

AutoGLM-Phone-9B多模态功能体验:图像识别与语音处理实战演示 1. 模型概述与核心能力 1.1 移动端优化的多模态大模型 AutoGLM-Phone-9B是一款专为移动端和边缘计算场景设计的轻量化多模态大语言模型。该模型在保持强大语义理解能力的同时,通过创新的架…...

League Akari:5大自动化引擎重构英雄联盟游戏体验

League Akari:5大自动化引擎重构英雄联盟游戏体验 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 一、从"机械操作"到&q…...

Janus-Pro-7B步骤详解:如何上传本地图片+输入自然语言提问

Janus-Pro-7B步骤详解:如何上传本地图片输入自然语言提问 1. 认识Janus-Pro-7B:新一代多模态AI模型 Janus-Pro-7B是一个创新的多模态AI模型,它能够同时理解和生成文本与图像内容。这个模型的最大特点是采用了一种独特的自回归框架&#xff…...

Retinaface+CurricularFace效果展示:多光照环境下考勤打卡成功率实测

RetinafaceCurricularFace效果展示:多光照环境下考勤打卡成功率实测 1. 测试背景与意义 企业考勤系统的人脸识别功能经常面临光照变化的挑战。早晨的侧光、中午的顶光、傍晚的逆光,这些自然光变化会导致传统人脸识别模型的准确率大幅波动。我们使用Ret…...

Nginx\Tomcat\Jetty\Netty

Nginx:高性能 HTTP 服务器 / 代理大门,接收请求、转发、负载均衡、静态资源、高并发纯异步非阻塞 多进程1 个 master 多个 worker一个线程能扛几万并发,整体能抗~10WQps只负责:接收请求 → 转发 → 返回结果Tomcat:J…...

YOLOv12跨平台开发指南:Python、C++、Rust多语言实现终极教程

YOLOv12跨平台开发指南:Python、C、Rust多语言实现终极教程 【免费下载链接】yolov12 [NeurIPS 2025] YOLOv12: Attention-Centric Real-Time Object Detectors 项目地址: https://gitcode.com/gh_mirrors/yo/yolov12 YOLOv12作为NeurIPS 2025最新发布的注意…...

彻底移除Windows Defender:释放30%系统性能的终极指南

彻底移除Windows Defender:释放30%系统性能的终极指南 【免费下载链接】windows-defender-remover A tool which is uses to remove Windows Defender in Windows 8.x, Windows 10 (every version) and Windows 11. 项目地址: https://gitcode.com/gh_mirrors/wi/…...

开源番茄小说下载工具:让数字阅读摆脱平台依赖的完整方案

开源番茄小说下载工具:让数字阅读摆脱平台依赖的完整方案 【免费下载链接】fanqienovel-downloader 下载番茄小说 项目地址: https://gitcode.com/gh_mirrors/fa/fanqienovel-downloader 当你在通勤途中想继续阅读昨晚未看完的小说,却发现网络信号…...

一文了解大模型:Token、上下文、计费与选型

一、前言想象你走进一家餐厅,菜单上写着"按食材重量计费"。你点了一碗面,但结账时发现:面条、汤底、葱花全都算重量,而且不同食材单价不同。大模型的 Token 计费,本质上就是这么回事。大模型(Lar…...

AndroidX Media3与ExoPlayer集成实战:从零构建视频播放器

1. 为什么选择AndroidX Media3和ExoPlayer 如果你正在开发一个Android视频播放应用,可能会纠结该用系统自带的MediaPlayer还是第三方方案。我做过十几个视频类项目,实测下来ExoPlayer绝对是首选。这个谷歌开源的播放器不仅性能强悍,还支持DAS…...

专业B站视频下载解决方案:实现4K高清与大会员内容本地化存储

专业B站视频下载解决方案:实现4K高清与大会员内容本地化存储 【免费下载链接】bilibili-downloader B站视频下载,支持下载大会员清晰度4K,持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader Bilibili-dow…...

保姆级教程:用PyTorch复现DALL·E核心组件之dVAE(含Gumbel-Softmax实现)

从零构建DALLE的视觉词库:PyTorch实现dVAE与Gumbel-Softmax实战 当我们需要将高分辨率图像压缩为紧凑的离散表示时,离散变分自动编码器(dVAE)提供了一种优雅的解决方案。本文将深入探讨如何用PyTorch实现DALLE中的dVAE组件&#x…...

告别复杂对抗训练:用Python+PyTorch实现傅里叶域自适应(FDA),5分钟搞定语义分割的域迁移

5行代码实现傅里叶域自适应:用PythonPyTorch零成本完成语义分割域迁移 当你在GTA5游戏画面训练的模型遇到真实街景时,准确率突然暴跌30%——这是计算机视觉工程师最熟悉的噩梦。传统域自适应方法往往需要复杂的对抗训练和精细调参,而2020年CV…...

TensorFlow 2.x与Keras完美融合:构建深度学习模型的终极教程

TensorFlow 2.x与Keras完美融合:构建深度学习模型的终极教程 【免费下载链接】TensorFlow Project containig related material for my TensorFlow articles 项目地址: https://gitcode.com/gh_mirrors/ten/TensorFlow 想要快速掌握TensorFlow 2.x与Keras的完…...

ROFL播放器:5分钟解决英雄联盟回放播放难题的终极指南

ROFL播放器:5分钟解决英雄联盟回放播放难题的终极指南 【免费下载链接】ROFL-Player (No longer supported) One stop shop utility for viewing League of Legends replays! 项目地址: https://gitcode.com/gh_mirrors/ro/ROFL-Player 还在为英雄联盟回放文…...

【Tessent Shell实战指南】【Ch4】层次化设计中的DFT架构规划与实现策略

1. 层次化DFT设计基础与挑战 第一次接触大型SoC层次化设计时,我被复杂的时钟域和物理分区搞得晕头转向。直到在Tessent Shell中实践了完整的hierarchical DFT流程,才发现这套方法论的精妙之处。层次化DFT就像搭积木,需要先规划整体结构&…...

智能运维避坑指南:高压断路器机器学习诊断中的5大常见数据陷阱

智能运维避坑指南:高压断路器机器学习诊断中的5大常见数据陷阱 在电力系统智能运维的浪潮中,高压断路器作为电网的"安全卫士",其故障诊断的准确性与及时性直接关系到整个电网的稳定运行。随着机器学习技术在工业领域的深入应用&…...

LangGraph从入门到精通(二)——构建你的第一个有状态智能体

1. 环境准备与基础概念回顾 在开始构建有状态智能体之前,我们需要先确保开发环境就绪。我推荐使用Python 3.10版本,这个版本在稳定性和新特性支持上达到了很好的平衡。安装LangGraph非常简单,只需要一条命令: pip install langgra…...

PyDPF-Core新手避坑指南:解决grpc._channel._InactiveRpcError的3种实战方法

PyDPF-Core实战:彻底解决grpc._channel._InactiveRpcError的深度指南 当你第一次在PyDPF-Core中看到grpc._channel._InactiveRpcError这个错误时,可能会感到困惑——明明代码看起来没问题,为什么连接会失败?这个问题困扰过不少刚接…...