Java代码手段防止非法请求,思路如下:
        1. 获取到当前请求的域名,如www.a.com
        2. 获取到请求资源的上一个地址
        3. 判断上一个地址是否为空,如果为空代表的是直接访问的资源,非法
         还有一种情况就是B项目访问时上一个地址www.b.com/xxx 不是资源所在地址,非法
         新建一个过滤器,实现逻辑,如果非法则显示图像,拦截return   ,否则放行

过滤器:

 package com.chx;

 import java.io.IOException;

 import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class ImageFilter implements Filter{ @Override
public void destroy() {
System.out.println("销毁");
} @Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
System.out.println("dofilter");
//转换成HttpServlet对象
HttpServletRequest httprequest=(HttpServletRequest)request;
HttpServletResponse httpresponse=(HttpServletResponse)response; //获取上一个地址
String referer = httprequest.getHeader("Referer");
String serverName = httprequest.getServerName();
System.out.println(referer+"\t"+serverName);
//如果地址为空,则有可能是直接访问资源
//地址不正确,则是非法访问请求
if(referer==null||!referer.contains(serverName)) {
//转发到非法提示
request.getRequestDispatcher("/img/ffqq.png").forward(request, response);
return;
} //资源放行
chain.doFilter(request, response); } @Override
public void init(FilterConfig arg0) throws ServletException {
System.out.println("初始化");
} }

web.xml

 <!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app>
<display-name>Archetype Created Web Application</display-name>
<filter>
<filter-name>imgFilter</filter-name>
<!--指向自己配置的过滤器类-->
<filter-class>com.chx.ImageFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>imgFilter</filter-name>
<!--过滤img文件夹下的所有文件-->
<url-pattern>/img/*</url-pattern>
</filter-mapping>
</web-app>

执行结果

1.正常访问——在本项目中通过请求访问资源

Java代码手段防止非法请求——防盗链-LMLPHP

 2.非法访问——直接访问资源地址

Java代码手段防止非法请求——防盗链-LMLPHP

 3.非法访问——通过其他项目访问本项目资源

Java代码手段防止非法请求——防盗链-LMLPHP

Java代码手段防止非法请求——防盗链-LMLPHP

通过这种判断上一个请求地址(Referer)的方式,就可达到过滤非法请求的目的。

05-11 22:18