WEB.XML
authFilter
jp.cofesta.framework.web.filter.AuthorityFilter
encodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
struts2
org.apache.struts2.dispatcher.FilterDispatcher
<filter-mapping>
<filter-name>authFilter</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>*.*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
过滤器 实现类
public class AuthorityFilter extends OncePerRequestFilter {
private String error = "/logout.action";
/**
* error action setter method
*
* @param error
*/
public void setError(String error) {
this.error = error;
}
/**
* filter
*
* @param request
* @param response
* @param filterChain
*/
protected void doFilterInternal(HttpServletRequest request,
HttpServletResponse response, FilterChain filterChain)
throws IOException, ServletException {
String requestURI = request.getRequestURI();
//String shortRequestURI = requestURI.replace(request.getContextPath(),"");
//ServletActionContext sac = new ServletActionContext(null,null);
ServletActionContext.setRequest(request);
User user = SecurityUtil.getLoginUser();
if (requestURI.endsWith(error)) {
filterChain.doFilter(request, response);
}else if (user == null && !requestURI.endsWith(Constants.LOGINACTION)
&& !requestURI.endsWith(Constants.WELCOMEACTION)) {
String forwardPath = request.getContextPath() + error;
(new HttpServletResponseWrapper(response))
.sendRedirect(forwardPath);
} else {
filterChain.doFilter(request, response);
}
}
}
错误信息如下:
2010-8-25 13:34:56 org.apache.catalina.core.StandardWrapperValve invoke
严重: Servlet.service() for servlet default threw exception
java.lang.NullPointerException
at org.apache.struts2.ServletActionContext.setRequest(ServletActionContext.java:103)
at cc.yilian.invoicing.common.filter.AuthorityFilter.doFilterInternal(AuthorityFilter.java:51)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:75)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Unknown Source)
package com.xfaccp.filter;
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.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import com.xfaccp.bean.UserBean;
public class CheckLoginFilter implements Filter {
public void destroy() {
// TODO Auto-generated method stub
}
public void doFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain arg2) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest)arg0;
String url = request.getServletPath();
HttpSession session = request.getSession();
UserBean user = (UserBean)session.getAttribute("user");
if(url.indexOf("LoginServlet") > 0)
{
arg2.doFilter(arg0, arg1);
}
else if(user == null || user.getId() < 1)
{
request.setAttribute("loginError", "请先登录!");
request.getRequestDispatcher("/jsp/login.jsp").forward(arg0, arg1);
}else
{
arg2.doFilter(arg0, arg1);
}
}
public void init(FilterConfig arg0) throws ServletException {
// TODO Auto-generated method stub
}
}
用Spring的过滤器
<!-- Filter 定义 -->
<!-- Character Encoding filter -->
encodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
forceEncoding
true
哦,自定义过滤器验证用户登录状态
一般处理是在登录过滤器中获取保存用户的session的用户当取不到用户时即NULL时跳转到登录页面
上面的错误是表示你的AuthorityFilter.java:51行有错误是一个NullPointerException 异常
你的代码有点晕,首先你是那什么来判断用户是否登录的,,都没看到页面传的参数。。。。
你的那个SecurityUtil放的是获取session的吧
建议使用
HttpServletRequest request = ServletActionContext.getRequest();
request.getSession().getAttribute("")的形式