使用過濾器監聽所有進入tomcat(不是專案)的請求並做處理
tomcat自帶的配置可以對所有訪問的ip進行統計,並記錄到日誌中,但是如果想要 對請求做一些處理,
比如:對ip做一些格式化的操作,tomcat做了磁碟地址對映之後對直接的檔案url請求做響應時的Header處理以解決跨域問題等
這時怎麼做呢?
下面實操步驟:
自定義一個過濾器CORSFilter.java,程式碼如下:
package com.cors.filter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.PrintStream;
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.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class CORSFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
System.out.println("進入了Filter方法");
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
// 對響應內容中修改Header,以解決同源問題
httpResponse.setHeader("Access-Control-Allow-Origin", "*");
System.out.println("攔截請求:" + httpRequest.getRequestURI());
chain.doFilter(httpRequest, httpResponse);
}
@Override
public void destroy() {
// TODO Auto-generated method stub
}
}
將上述程式碼打成jar包,打包方式自行百度,得到jar包,CORSFilter.jar
將jar包放入tomcat的lib目錄下
配置conf/web.xml,
<filter>
<filter-name>corsFilter</filter-name>
<filter-class>com.cors.filter.CORSFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>corsFilter</filter-name>
<url-pattern>*.mp4</url-pattern>
</filter-mapping>
放到 ===Built In Filter Definitions=== 之下的位置
開啟tomcat,現在會對所有以.mp4請求的訪問地址進行攔截,並將響應時的Header部分添指定的資料,
該方式因為不涉及專案,會對所有的到達tomcat的請求進行攔截處理,
如果有更好的方式,歡迎討論
希望給可以幫到各位