request.getHeader("referer")的作用

在开发web程序的时候,有时我们需要得到用户是从什么页面连过来的,这就用到了referer。
它是http协议,所以任何能开发web程序的语言都可以实现,比如jsp中是:
request.getHeader("referer");
php是$_SERVER['HTTP_REFERER']。其他的我就不举例了(其实是不会其他的语言)。

js的话就是这样做:javascript:document.referrer
那它能干什么用呢?我举两个例子:
1,防止盗连,比如我是个下载软件的网站,在下载页面我先用referer来判断上一页面是不是自己网站,如果不是,说明有人盗连了你的下载地址。
2,电子商务网站的安全,我在提交信用卡等重要信息的页面用referer来判断上一页是不是自己的网站,如果不是,可能是黑客用自己写的一个表单,来提交,为了能跳过你上一页里的javascript的验证等目的。
使用referer的注意事项:
如果我是直接在浏览器里输入有referer的页面,返回是null(jsp),也就是说referer只有从别的页面点击连接来到这页的才会有内容。
我做了个实验,比如我的referer代码在a.jsp中,它的上一页面是b.htm,c.htm是一个带有iframe的页面,它把a.jsp嵌在iframe里了。我在浏览器里输入b.htm的地址,然后点击连接去c.htm,那显示的结果是b.htm,如果我在浏览器里直接输入的是c.htm那显示的是c.htm

在单元测试中,直接调用`request.getHeader("referer")`方法是无法获取到值的,因为单元测试是在没有实际的HTTP请求的情况下执行的。但是我们可以通过模拟HTTP请求的方式来设置`Referer`头。 在Java中,可以使用一些测试框架,如JUnit或Mockito,来模拟HTTP请求。下面是一个使用Mockito框架模拟HTTP请求并设置`Referer`头的示例: ```java import org.junit.Test; import org.mockito.Mockito; import javax.servlet.http.HttpServletRequest; public class MyTest { @Test public void testRefererHeader() { // 创建HttpServletRequest对象的Mock实例 HttpServletRequest request = Mockito.mock(HttpServletRequest.class); // 设置模拟的Referer头值 Mockito.when(request.getHeader("referer")).thenReturn("http://www.example.com"); // 在测试代码中使用request.getHeader("referer")来获取Referer头值 String referer = request.getHeader("referer"); // 断言Referer头值是否正确 assert referer.equals("http://www.example.com"); } } ``` 在上面的示例中,我们使用`Mockito.mock(HttpServletRequest.class)`创建了一个HttpServletRequest的Mock对象,然后通过`Mockito.when(request.getHeader("referer")).thenReturn("http://www.example.com")`设置了`Referer`头的值为"http://www.example.com"。接下来,我们可以在测试代码中使用`request.getHeader("referer")`来获取设置的`Referer`头值,并进行断言验证。 请注意,这只是一种模拟HTTP请求的方式,实际应用中可能还需要根据具体的测试框架和场景进行适当的调整。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值