防止非法链接(referer)

本文介绍了一个简单的Servlet实现,该实现通过检查HTTP请求头中的Referer字段来判断请求是否合法,以此达到防盗链的目的。具体实现包括了如何获取请求头中的Referer信息,并根据其来源决定是否提供资源。
转载:https://blog.youkuaiyun.com/QQ1012421396/article/details/62430154

前言:

HTTP Referer是header的一部分,当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器藉此可以获得一些信息用于处理。比如从我主页上链接到一个朋友那里,他的服务器就能够从HTTP Referer中统计出每天有多少用户点击我主页上的链接访问他的网站。

Referer的正确英语拼法是referrer。由于早期HTTP规范的拼写错误,为了保持向后兼容就将错就错了。其它网络技术的规范企图修正此问题,使用正确拼法,所以目前拼法不统一。

案例:通过获取请求头中的referrer,来判断是否是非法链接

意思就是为了防止
直接访问下载的资源
不是从广告页面过来的链接

服务端Servlet:

package a;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class dd
 */
@WebServlet("/dd")
public class dd extends HttpServlet {
    private static final long serialVersionUID = 1L;
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        response.setContentType("text/html;charset=utf-8");
        //得到referer头
        String referer = request.getHeader("referer");
        System.out.println("referer="+referer);
        /**
        * 判断非法链接:
        * 1)直接访问的话referer=null
        * 2)如果当前请求不是来自广告
        */
        if(referer==null || !referer.contains("/haha/NewFile.html")){
        response.getWriter().write("当前是非法链接,请回到首页。<a href='/haha/NewFile.html'>首页</a>");
        }else{
        //正确的链接
        response.getWriter().write("资源正在下载...");
        }
    }


}

客户端:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
广告内容,请猛戳这里。<br/>
<a href="/haha/dd">点击此处下载</a>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值