查看请求来源--防盗链

本文介绍了一种简单的防止跨站请求伪造(CSRF)的方法:通过检查HTTP请求头中的Referer字段来验证请求来源。如果Referer不是来自预期的域名,则认为该请求可能存在问题。

简单方法,很容易被绕过,但是万事从简单开始,记录下来。

 

原理很简单,判断一下请求头中,Referer是否是自己工程的域名,如果不是,就是有问题。

request.getHeader( " Referer " );

null ==  request.getHeader( " Referer " ) || request.getHeader( " Referer " ).indexOf( " yourdomain.com " <   0


利用Referer实现防盗链是一种常见的网络资源保护手段,下面将详细介绍其原理、方法及应用。 ### 原理 HTTP标准协议中有专门的字段记录Referer,它可以追溯到请求是从哪个网站链接过来的,对于资源文件,还能跟踪到包含显示它的网页地址。基于此,很多防盗链方法都是利用这个Referer字段。例如,当用户在网页1点击一个链接到网页2,浏览器请求网页2时,网页1的URL就会包含在Referer头信息中。通过检查这个Referer信息,服务器就能判断请求来源是否合法 [^1]。 ### 方法 要实现Referer防盗链,通常需要在资源显示之前进行来源验证。以图片资源为例,当有请求访问图片时,服务器会检查请求头中的Referer字段。如果Referer字段的值表明请求来自合法的网站(如本网站内的网页),则正常显示图片;如果来自不合法的网站(如其他网站对本网站图片资源的引用),则显示一个错误图片。这通常借助Filter来实现,Filter的工作区域是在客户端请求request抵达Servlet之前和服务器响应response从Servlet抵达客户端浏览器之前,起到了一个过滤网的作用 [^2]。 ### 应用 Referer防盗链在实际应用中非常广泛。例如,在论坛中,经常会看到别人贴的图显示出来是一个错误图片,这可能是因为该论坛使用了Referer防盗链机制,禁止其他网站引用本论坛的图片资源。百度图片也不允许外链,也是利用了这种防盗链技术,只有从百度内部页面发起的图片请求才能正常获取图片,其他网站的引用则会被阻止 [^2]。 以下是一个简单的Java代码示例,展示如何在Servlet中检查Referer实现简单的防盗链: ```java import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; public class AntiLeakServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String referer = request.getHeader("Referer"); if (referer != null && referer.startsWith("http://合法域名")) { // 合法请求,处理资源 // 这里可以是返回图片、文件等操作 } else { // 非法请求,返回错误信息或错误图片 response.sendError(HttpServletResponse.SC_FORBIDDEN); } } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值