JSP——request.getHeader(referer)的使用

request.getHeader("referer")获取来访者地址。只有通过链接访问当前页的时候,才能获取上一页的地址;

否则request.getHeader("referer")的值为null,通过window.open打开当前页或者直接输入地址,也为null。

若从 http://xxx/a.jsp 上 点击 a标签 至 http://XXXX/b.jsp

b.jsp 获取 request.getHeader("referer") 返回 http://xxx/a.jsp

原文:https://blog.csdn.net/zhanghaipeng1989/article/details/19477753
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 创建一个过滤器类 MyFilter,实现 javax.servlet.Filter 接口。 ``` public class MyFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { // 初始化方法 } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 过滤方法 } @Override public void destroy() { // 销毁方法 } } ``` 2. 在 doFilter 方法,判断请求是否来自本站。如果是本站请求,直接放行;否则,跳转到非法访问提示页面。 ``` public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest httpRequest = (HttpServletRequest) request; String referer = httpRequest.getHeader("referer"); if (referer != null && referer.contains(request.getServerName())) { // 来自本站的请求,直接放行 chain.doFilter(request, response); } else { // 非法访问,跳转到提示页面 HttpServletResponse httpResponse = (HttpServletResponse) response; httpResponse.sendRedirect("/illegalAccess.html"); } } ``` 3. 在 web.xml 文件配置过滤器。 ``` <filter> <filter-name>myFilter</filter-name> <filter-class>com.example.MyFilter</filter-class> </filter> <filter-mapping> <filter-name>myFilter</filter-name> <url-pattern>/images/*</url-pattern> </filter-mapping> ``` 4. 在项目根目录下创建 illegalAccess.html 文件,用于显示非法访问提示信息。 这样,当用户直接访问图片时,会被 MyFilter 拦截,并跳转到非法访问提示页面;而当用户从本站页面链接过来时,可以正常显示图片。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值