通过Referer请求头实现防盗链

通过Referer请求头实现防盗链

盗链: 其他站点通过超链接等连接到我们自己的站点窃取我们的资源的行为就称之为盗链. 
Referer请求头: 代表当前访问时从哪个网页连接过来的.
 
Example:
加入我们有一个新闻网站,在相关人员的努力下终于采访到一个重磅新闻,因此我们将该新闻放置到我们网站的官方首页上,通过超链接进行访问.
 
<a href="${pageContext.request.contextPath }/NewsServlet">重磅新闻</a>
@WebServlet("/NewsServlet")
public class NewsServlet extends HttpServlet {
private static final long serialVersionUID = 1L;

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");

response.getWriter().write("本大侠吃包子....");
}


protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
 
现在有一个其他网站, www.xianglang.com 没有新闻,看见了该新闻很受大家喜欢就在自己的主页上加了如下超链接
 
<a href="http://localhost/Day04-Response-Request/NewsServlet">特大新闻</a>
 
这样,我们费尽努力得到的资源就被别人轻易的窃取了,这就是盗链行为.
 
为了防止该行为我们可以通过 Referer请求头实现防盗链:
修改NewsServlet如下:
 
@WebServlet("/NewsServlet")
public class NewsServlet extends HttpServlet {
private static final long serialVersionUID = 1L;

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");

String referer = request.getHeader("Referer");
if(referer == null || "".equals(referer) || !referer.contains("localhost/")) {
response.sendRedirect(request.getContextPath() + "/index.jsp");
return;
}


response.getWriter().write("本大侠吃包子....");
}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
 
当Referer未存在或者是从其他站点访问我们资源的时候就直接重定向到我们的主页,这样既可以防止我们的资源被窃取, 而且可以将其他试图盗链的站点的用户慢慢转化为我们站点的用户.
 
注意: 重定向之后要return, 否则资源也会被窃取.
 
 
 
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值