web.xml下的拦截器配置
<filter>
<filter-name>LogFilter</filter-name>
<filter-class>org.zyyd.base.filter.LogFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LogFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
LogFilter文件实例:
package************r;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.SecurityUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zyyd.base.entity.BaseUser;
import org.zyyd.base.util.LogUtil;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URLDecoder;
import java.util.HashMap;
import java.util.Map;
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 LogFilter implements Filter{
private static Logger logger = LoggerFactory.getLogger(LogFilter.class);
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletResponse theResponse=((HttpServletResponse) response);
HttpServletRequest theRequest=((HttpServletRequest) request);
Map<String,Object> logMessage = new HashMap<String,Object>();
String path=theRequest.getServletPath();
if(StringUtils.isBlank(path)){
path = "";
}
String ext="";
if(path.lastIndexOf(".")==-1){
}else{
ext=path.substring(path.lastIndexOf("."), path.length());
}
if(".js".equals(ext) || ".css".equals(ext)){
chain.doFilter(request, response);
return;
}
logMessage.put("path",path);
try {
BaseUser user = (BaseUser) SecurityUtils.getSubject().getPrincipals().getPrimaryPrincipal();
if(user.getUserId() != null){
logMessage.put("hasLogin",true);
logMessage.put("userId",user.getUserId());
logMessage.put("loginName",user.getLoginName());
logMessage.put("roleCodes",user.getRoleCodes());
}else{
logMessage.put("hasLogin",false);
}
} catch (Exception e) {
// e.printStackTrace();
logMessage.put("hasLogin",false);
// 如果访问的是接口的话
if(path.startsWith("/enginApi/")){
// 1.接口标记打上
logMessage.put("isApi",true);
// 2.访问访问权限
StringBuffer info = new java.lang.StringBuffer();
InputStream in = request.getInputStream();
BufferedInputStream buf = new BufferedInputStream(in);
byte[] buffer = new byte[1024];
int iRead;
while ((iRead = buf.read(buffer)) != -1) {
info.append(new String(buffer, 0, iRead, "UTF-8"));
}
// 通过read方法读取一个文件 转换成Document对象
String jsonStr = new String();
jsonStr = info.toString();
jsonStr = URLDecoder.decode(jsonStr, "utf-8");
JSONObject json = JSON.parseObject(jsonStr);
logMessage.put("domainId",json.get("domainId"));
logMessage.put("domainPassWord",json.get("domainPassWord"));
logMessage.put("jsonStr",jsonStr);
}
}
if("".equals(ext) || ".html".equals(ext)){
LogUtil.info(logMessage);
}
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
}