本内容是旧版,有点错误
使用File来实现
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
// TODO Auto-generated method stub
HttpServletRequest req = (HttpServletRequest) request;
HttpServletResponse res = (HttpServletResponse) response;
//获取链接
String referer=req.getHeader("referer");
//获取本电脑ip地址
String serverName=req.getServerName();
if(referer==null||!referer.contains(serverName)||referer.contains("mp4")){
req.getRequestDispatcher("/images/timg.jpg").forward(req, res);
return;
}
chain.doFilter(req, res);
}
RefererFilter
com.enet.fileter.RefererFilter
RefererFilter
/mp4/*
如上代码就实现了防盗链防下载功能,
防盗链指的是在网站上无法通过资源的链接直接访问到
防下载指的是在下载软件中无法用过资源的链接下载到对应的资源
防盗链和防下载最主要的区别:referer获取到的值
在防盗链中referer获取到的值是本网站的链接地址
在防下载中referer获取到的值是本资源的地址
防盗链和防下载道理是一样的,想访问该资源(图片,视频)就会替换其他的资源