图片防盗链

 

 <filter>
  <filter-name>imageRedirectFilter</filter-name>
  <filter-class>upload.ImageRedirectFilter</filter-class>
  </filter>
  <filter-mapping>
<filter-name>imageRedirectFilter</filter-name>
<url-pattern>/upload/*</url-pattern>
</filter-mapping>

 

 

package upload;

import java.io.IOException; import java.util.Properties;

import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.Filter; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.FilterChain;

public class ImageRedirectFilter implements Filter {

public void init(FilterConfig config) throws ServletException { }

public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {

HttpServletRequest request = (HttpServletRequest) req; HttpServletResponse response = (HttpServletResponse) res;

// 禁止缓存 response.setHeader("Cache-Control", "no-store"); response.setHeader("Pragrma", "no-cache"); response.setDateHeader("Expires", 0);

// 链接来源地址 String referer = request.getHeader("referer"); System.out.println("refer is"+referer);

Properties properties = new Properties(); properties.load(ImageRedirectFilter.class.getClassLoader()   .getResourceAsStream("config.properties")); String serverUrls = properties.getProperty("serverUrls"); String [] urls = serverUrls.split(",");

boolean bool = true; for(int i=0;i<urls.length;i++){  String url =urls[i];  if (referer.contains(url)){   bool = false;   break;  } }

 

if (referer == null || bool) {

/** * 如果 链接地址来自其他网站,则返回错误图片 */ request.getRequestDispatcher("/error.jpg").forward(request, response);

} else {

/** * 图片正常显示 */ //chain.doFilter(request, response);  request.getRequestDispatcher("/012.jpg").forward(request, response); }

}

public void destroy() { } }

 

转载于:https://www.cnblogs.com/IT-WJ/archive/2013/05/04/3059301.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值