首页 » 排名链接 » 我学会了做网站的防盗链(防盗链资源请求自己的不被)

我学会了做网站的防盗链(防盗链资源请求自己的不被)

落叶飘零 2024-11-03 12:08:25 0

扫一扫用手机浏览

文章目录 [+]

术语听得有点迷糊?那我们简单的举个栗子:

平时我们在TX网看,里边有很多劲爆的图片、视频资源,每天吸引上亿的用户活跃浏览,赚着大把的广告费。

有一天一个穷比程序员小富突发奇想,也想建一个自己的网站吸引用户赚广告费,但苦于自己没有资源,他灵光一闪盯上了TX网,心想:要是把它的资源为我所用,这样就能借助TX的资源为自己赚钱。

我学会了做网站的防盗链(防盗链资源请求自己的不被) 排名链接
(图片来自网络侵删)

于是他通过爬虫等一些列技术手段,把TX网资源拉取到自己的小富网,绕过了TX网的展示页面直接呈现给用户,达到了自己不提供资源又能赚钱的目的。

而如此做法却严重的损害了TX网的利益,不仅分流了大量用户,而且由于小富网的大量间接资源请求,大大增加TX网服务器及带宽的压力。

TX网蛋糕被动,忍无可忍决定封杀小富网这类空手套白狼的站点,终于祭出防盗链系统,对除了在TX网本站以外发起的资源请求全部封杀,小富网没法再拉取资源,小富一下子又成了穷比,嘤嘤嘤~

上边我们简单的举例说了什么是网站的盗链,再总结的简单点就是小站点盗取大站点资源以此来获利的一种行为。

既然有人盗就会有人防盗,接下来在看看怎么防止盗链。

如何防盗链

防盗链在google,新浪,网易,天涯等,内容为主的网站应用的比较多,毕竟主要靠资源内容赚钱的嘛。

在这里插入图片描述

提到防盗链的实现原理得从HTTP协议说起,上边我们说过设置防盗链以后,会对 “除了在TX网本站以外发起的资源请求全部封杀”,那么问题来了,如何识别一个请求URL是从哪个站点发出的呢?

熟悉HTTP协议的小伙伴应该知道,在HTTP协议头里有一个叫referer的字段,通过referer 告诉服务器该网页是从哪个页面链接过来的,知道这个就好办了,只要获取 referer 字段,一旦检测到来源不是本站即进行阻止或者返回指定的页面。

防盗链的核心理念:尽量做到不让外站获取到我的资源,即便能通过一些手段获取到资源,也让你的获取过程异常繁琐复杂,无法实现自动化处理,或者干脆就给你有问题的资源恶心死你。

做防盗链的方法比较多,基于HTTP协议头的referer属性也只是其中一种,下边我们来分析几种实现防盗链的方法,如果你有更好的实现方法欢迎留言哦。

基于 HTTP 协议的 referer

基于HTTP协议中的 referer做防盗链,可以从网关层或者利用AOP、Filter拦截器实现。

使用Nginx在网关层做防盗链,目前是最简单的方式之一。
通过拦截访问资源的请求,valid_referers 关键字定义了白名单,校验请求头中referer地址是否为本站,如不是本站请求,rewrite 转发请求到指定的警告页面。

在 server 或者 location 配置模块中加入:valid_referers none blocked,其中 none : 允许没有http_refer的请求访问资源(比如:直接在浏览器输入图片网址);blocked : 允许不是http://开头的,不带协议的请求访问资源。

「注意」:这种实现可以限制大多数普通的非法请求,但不能限制有目的的请求,因为可以通过伪造referer信息来绕过。

[root@server1nginx]#vimconf/nginx.conflocation/{root/web;indexindex.html;}location~\.(gif|jpg|png|jpeg)${root/web;valid_referersnoneblockedwww.chengxy-nds.top;if($invalid_referer){#return403;rewrite^/https://img-blog.csdnimg.cn/20200429152123372.png;}}server{listen80;server_namewww.chengxy-nds.top;location/{root/bbs;indexindex.html;}}[root@server1nginx]#systemctlrestartnginx

Filter拦截器的实现方式更加简单,拦截指定请求URL,拿到HttpServletRequest 中 referer值比对是否为本站。

publicclassMyFilterimplementsFilter{@OverridepublicvoiddoFilter(HttpServletRequestrequest,HttpServletResponseresponse,FilterChainchain)throwsIOException,ServletException{HttpServletRequestreq=(HttpServletRequest)request;HttpServletResponseres=(HttpServletResponse)response;Stringreferer=req.getHeader("referer");if(referer==null||!referer.contains(req.getServerName())){req.getRequestDispatcher("XXX.jpg").forward(req,res);}else{chain.doFilter(request,response);}}}登录验证,禁止游客访问

登录验证这种就属于一刀切的方式,一般在论坛、社区类网站使用比较多,不管你发起请求的站点是什么,到我这先登录,没登录请求直接拒绝,简单又粗暴。

图形验证码

图形验证码是一种比较常规的限制办法,比如:下载资源时,必须手动操作验证码,使爬虫工具无法绕过校验,起到保护资源的目的。

实现防盗链的方式还有很多,这里就不一一列举了(别问,问就是还有很多)。

总结

本来没想写这篇文章,下午搭建自己的博客整理资料,白嫖别人资源没成功有感而发,哈哈哈~ 正好借此机会简单的介绍一下防盗链的概念,提醒 everyone 在开发中要提高安全意识。
其实盗链与防盗链就是像是矛与盾一样,说不好是矛更锋利还是盾更坚固,做不到绝对的防盗。
道高一尺魔高一丈,盗链的手段越高,相应的防盗技术也会越成熟。

小福利:

整理了几百本各类技术电子书相送 ,嘘~,「免费」 送给小伙伴们,私信或者评论【666】自行领取。
和一些小伙伴们建了一个技术交流群,一起探讨技术、分享技术资料,旨在共同学习进步。

标签:

相关文章

网络世界的基石_六大网络协议的奥秘

在当今这个信息化时代,网络已经成为我们生活中不可或缺的一部分。而网络世界的运转离不开各种协议的支撑,其中六大网络协议更是构成了网络...

排名链接 2025-01-01 阅读1 评论0

语言模式在书籍创作中的应用与方法

随着时代的发展,书籍已经成为人们获取知识、启迪思想的重要途径。优秀的书籍往往具有独特的语言魅力,能够吸引读者,引发共鸣。本文将探讨...

排名链接 2025-01-01 阅读1 评论0

跨语言沟通的魅力,构建全球化的桥梁

随着全球化的不断深入,跨语言沟通已经成为人们日常生活和工作中不可或缺的一部分。掌握三种语言不仅能够拓宽我们的视野,还能够帮助我们更...

排名链接 2025-01-01 阅读1 评论0