网站防盗链系统,打破了我的“发财梦”

简介: 网站防盗链系统,打破了我的“发财梦”

下午摸鱼的时候遇到了一件有意思的事,在网上找到一个资源站,将资源站的 url 放到自己的博客里,想白嫖一波,结果在我自己的博客里链接失效了,折腾半天忽然想起来,这个网站应该是做了防盗链处理。

什么是盗链

盗链是个什么操作,看一下百度给出的解释:盗链是指服务提供商自己不提供服务的内容,通过技术手段绕过其它有利益的最终用户界面(如广告),直接在自己的网站上向最终用户提供其它服务提供商的服务内容,骗取最终用户的浏览和点击率。受益者不提供资源或提供很少的资源,而真正的服务提供商却得不到任何的收益。
在这里插入图片描述
术语听得有点迷糊?那我们简单的举个栗子:

平时我们在TX网看新闻,里边有很多劲爆的图片、视频资源,每天吸引上亿的用户活跃浏览,赚着大把的广告费。
在这里插入图片描述
有一天一个穷比程序员小富突发奇想,也想建一个自己的网站吸引用户赚广告费,但苦于自己没有资源,他灵光一闪盯上了TX网,心想:要是把它的资源为我所用,这样就能借助TX的资源为自己赚钱。

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

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

TX网蛋糕被动,忍无可忍决定封杀小富网这类空手套白狼的站点,终于祭出防盗链系统,对除了在TX网本站以外发起的资源请求全部封杀,小富网没法再拉取资源,小富一下子又成了穷比,嘤嘤嘤~
在这里插入图片描述
上边我们简单的举例说了什么是网站的盗链,再总结的简单点就是小站点盗取大站点资源以此来获利的一种行为。

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

如何防盗链

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

在这里插入图片描述

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

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

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

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

基于 HTTP 协议的 referer

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

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

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

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

[root@server1 nginx]# vim conf/nginx.conf

      location / {
            root /web;
             index index.html;
      }
      location ~* \.(gif|jpg|png|jpeg)$ {
            root /web;
            valid_referers none blocked www.chengxy-nds.top;
            if ($invalid_referer){
                #return 403;
                rewrite ^/ https://ucc.alicdn.com/images/user-upload-01/20200429152123372.png;
         }
     }

     server {
         listen 80;
         server_name www.chengxy-nds.top;
         location / {
                 root /bbs;
                 index index.html;
         }
    }
    
[root@server1 nginx]# systemctl restart nginx

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

public class MyFilter implements Filter {
    @Override
    public void doFilter(HttpServletRequest request, HttpServletResponse response,
            FilterChain chain) throws IOException, ServletException {
            
        HttpServletRequest req = (HttpServletRequest) request;
        HttpServletResponse res = (HttpServletResponse) response;
        String referer = req.getHeader("referer");
        
        if (referer == null || !referer.contains(req.getServerName())) {
            req.getRequestDispatcher("XXX.jpg").forward(req, res);
        } else {
            chain.doFilter(request, response);
        }
    }
}
登录验证,禁止游客访问

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

图形验证码

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

在这里插入图片描述
实现防盗链的方式还有很多,这里就不一一列举了(别问,问就是还有很多)。

总结

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

小福利:
整理了几百本各类技术电子书相送 ,嘘~, 免费
送给小伙伴们。关注公众号【程序员内点事】回复【666】自行领取。和一些小伙伴们建了一个技术交流群,一起探讨技术、分享技术资料,旨在共同学习进步,如果感兴趣就扫码加入我们吧!
相关文章
|
PHP 开发工具 对象存储
如何实现网站的防盗链?
本文就是介绍类似A这样的用户将资源存放在OSS上后,如何设置防盗链来避免这样情况的发生。 本文适用那些在网页中使用了OSS资源作为外链的用户。
20136 0
|
9月前
|
数据采集 搜索推荐 安全
GMB外链的核心价值
答:通过自研的百万级外链站群系统,简单粗暴快速群发外链,就是快!就是多!就是强! GMB外链的核心价值 GMB外链已经成为现代SEO的关键部分,为网站带来了巨大的流量和可见性。 以下是对GMB外链核心价值的深入探讨以及它如何为你的业务带来益处。
62 0
GMB外链的核心价值
|
9月前
|
数据采集 监控 搜索推荐
GNB外链的核心价值
答:GNB外链的核心价值就是:安全性。提高网站外链资源构成的自然比例,规避谷歌判定网站过度SEO的指标,保障网站外链建设安全性 链接多样性与平衡 Nofollow与Dofollow的平衡 在建立外链时,一个均衡的Nofollow和Dofollow链接比例是至关重要的。 GNB外链正是为此而设计,帮助网站主动建设这种平衡的链接集群。 防止过度SEO的风险 对于Google优化而言,一个过度集中或单一的链接策略可能会被视为“过度SEO”,从而受到惩罚。 GNB外链的策略正是为了规避这一风险。
50 0
GNB外链的核心价值
|
10月前
|
数据采集 搜索推荐 安全
如何做外贸外链?
答案是:做GPB外链。 在外贸营销中,外链建设是提升网站排名、增加网站流量的重要手段。 但是,如何有效地进行外链建设,以及投入的谷歌SEO费用是否合理,这些都是我们需要关注的问题。 本文将为你介绍如何进行外贸外链建设,以及相关的谷歌SEO费用。 外贸外链建设方法 使用GPB外链 GPB外链是高质量的独立站外链,能有效的提升Google搜索引擎的自然排名。 通过建立与自己网站主题相关的外链,可以帮助提升谷歌搜索引擎的自然排名,从而增加网站的流量。
74 0
如何做外贸外链?
|
数据采集 分布式计算 前端开发
设置CDN防盗链规则来避免网站被恶意刷量
设置CDN防盗链规则来避免网站被恶意刷量
1868 1
|
缓存 安全
跨境电商养号防关联!用免费的沙盒Sandboxie做浏览器隔离!
在没有更多实体电脑的情况下,在同一台电脑上登同一平台不同地区账号且要保证不因为操作问题造成账号关联而导致风控
|
搜索推荐 算法 SEO
百度优化中不要走入外链的误区
众所周知外部关键字链接对网站提升排名具有不可估量的地位。有很多seoer为客户做搜索引擎优化的过程中或者会使用一些群发工具、或者会去花钱购买一些链接来为客户的网站增加外链从而达到提高排名的目的。精灵也使用过这样的方法,的确是非常有效,对于一些不太热门的关键词,甚至可以在短时间内把排名直接提到搜索的第一位。
|
搜索推荐 数据库 索引
外链的策略,怎么做外链才能更有利于SEO优化
外部链接在网站排名中的作用未知。那么,我们现在应该如何发送外链,以便您可以提高您的网站排名,而不受外界不利影响?<a rel="dofollow" href="https://www.fgba.net/" title="富贵论坛"><span style="color: rgba(38, 38, 38, 1)">富贵论坛</span></a>www.fgba.net建议以下几条原则。首先:外链相关性应该注意:其实,外链的本质是一个投票,是另一个网站为你的网站投票,那么显然最权威的投票来自同一类网站。
149 0
|
搜索推荐 算法 SEO
做外链要注意什么?外链建设的四个要素
外链建设的四个要素 我们知道外链,也许并不是SEO的全部,但通过链接,搜索引擎可以很好的统计目标网站链接的数量以及权威度,从而进一步判断,目标页面针对特定目标关键词,在搜索结果中的合理位置。 同时,它也是每次百度算法迭代更新重要的媒介,因此,在众多SEO技能里,外链资源建设仍然起着一定积极的作用。 外链建设的四个要素:相关性、收录率、权威性、稳定性,我们来一一解析。
170 0
网站外链建设注意事项有哪些
网站优化工作中,站内优化和站外优化都是非常重要的,站外优化主要是依据外链来提升网站的权重和流量,那么网站外链建设的过程中,需要主要哪些问题呢,给大家总结了以下几点。
127 0