您的位置:首页 > Web前端 > JavaScript

用户登录验证

2009-09-16 14:10 176 查看
  

  在WEB系统中,为了保护系统的安全性,通常有些功能是开放给合法用户的。此时需要对用

户是否已经登录进行验证。

  登录验证的方式可能有很多种,其中最常用的一种就是:对每个需要验证的JSP页面或者

Action都进行Session验证,通过判断Session中的属性值来确认用户是否登录!这样做虽

然可以进行登录验证,但是想象一下:如果你的系统非常庞大,有几百个Action和几百个

Action 此时,如果你还采用上述的方法来进行登录验证的话,那可就不是件好事。因为,这

意味着,你将写几百行、几千行重复的代码!

  别急,肯定有另外的验证方法的!我们可以通过Filter来进行过滤,比如对所有的JSP页

面、.do 进行拦截验证。如果通过验证,则进行执行相关业务逻辑。反之,则跳转到登陆页

1.定义一个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.HttpServletResponse;
import javax.servlet.http.HttpSession;

import com.lzkj.dealer.util.actionOperator;

public class urlFilter implements Filter {

public void destroy() {
// TODO Auto-generated method stub

}

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

HttpServletRequest request = (HttpServletRequest)req;
HttpServletResponse response = (HttpServletResponse)res;
System.out.println("Call Me Now");

String uri = actionOperator.getRealActionPath(request.getRequestURI());
System.out.println(uri);
HttpSession session = request.getSession();

if("/showmainpageAction.do".equals(uri)){
request.getRequestDispatcher("/showmainpageAction.do").forward(request, response);
return;
}
else if("/dealerloginAction.do".equals(uri)){
request.getRequestDispatcher(uri).forward(request, response);
return;
}else if(session.getAttribute("did")==null){
request.getRequestDispatcher("/showmainpageAction.do").forward(request, response);
return;
}
else{
request.getRequestDispatcher(uri).forward(request, response);
return;
}
}

public void init(FilterConfig arg0) throws ServletException {
// TODO Auto-generated method stub

}

}


2.在web.xml中配置定义好的Filter

 

<filter>
<filter-name>urlFilter</filter-name>
<filter-class>com.lzkj.filter.urlFilter</filter-class>
</filter>

<filter-mapping>
<filter-name>urlFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
  

3.测试一下,在地址输入栏中输入其它的URL试试(我这里只做了对.do的拦截验证,需要的

话可以自己添加其它的拦截验证类型)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息