java登录验过滤器_JAVA用过滤器验证登陆框架,简单实例

Java代码

public class SignOnFilter implements Filter{

FilterConfig fc;

public void destroy() {

// TODO Auto-generated method stub

}

public void doFilter(ServletRequest request, ServletResponse response,

FilterChain chain) throws IOException, ServletException {

// TODO Auto-generated method stub

HttpServletRequest hreq=(HttpServletRequest) request;

HttpServletResponse hres=(HttpServletResponse) response;

HttpSession session = hreq.getSession();

if(session!=null&&session.getAttribute("user")!=null)chain.doFilter(request, response);

else if(hreq.getRequestURI().equals(hreq.getContextPath()+"/login.jsp")){

if(valid(hreq,hres)) hres.sendRedirect(hreq.getContextPath()+"/index.jsp");

else chain.doFilter(request, response);

}

else hres.sendRedirect(hreq.getContextPath()+"/login.jsp");

}

public Boolean valid(HttpServletRequest hreq, ServletResponse hres){

String uName=hreq.getParameter("uName");

String uPassword=hreq.getParameter("uPasswd");

if(uName!=null&&uName.equals("admin")&&uPassword!=null&&uPassword.equals("admin")){

HttpSession session=hreq.getSession();

session.setAttribute("user", "admin");

return true;

}else return false;

}

public void init(FilterConfig fc) throws ServletException {

// TODO Auto-generated method stub

this.fc=fc;

}

}public class SignOnFilter implements Filter{ FilterConfig fc; public void destroy() { // TODO Auto-generated method stub } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // TODO Auto-generated method stub HttpServletRequest hreq=(HttpServletRequest) request; HttpServletResponse hres=(HttpServletResponse) response; HttpSession session = hreq.getSession(); if(session!=null&&session.getAttribute("user")!=null)chain.doFilter(request, response); else if(hreq.getRequestURI().equals(hreq.getContextPath()+"/login.jsp")){ if(valid(hreq,hres)) hres.sendRedirect(hreq.getContextPath()+"/index.jsp"); else chain.doFilter(request, response); } else hres.sendRedirect(hreq.getContextPath()+"/login.jsp"); } public Boolean valid(HttpServletRequest hreq, ServletResponse hres){ String uName=hreq.getParameter("uName"); String uPassword=hreq.getParameter("uPasswd"); if(uName!=null&&uName.equals("admin")&&uPassword!=null&&uPassword.equals("admin")){ HttpSession session=hreq.getSession(); session.setAttribute("user", "admin"); return true; }else return false; } public void init(FilterConfig fc) throws ServletException { // TODO Auto-generated method stub this.fc=fc; } }

Java代码

filter

signOnFilter

lib.SignOnFilter

signOnFilter

/*

index.html

index.htm

index.jsp

default.html

default.htm

default.jsp

<?xml version="1.0" encoding="UTF-8"?> filtersignOnFilterlib.SignOnFilter signOnFilter/*index.htmlindex.htmindex.jspdefault.htmldefault.htmdefault.jsp

用户只要更改valid函数,就能对用户名和密码进行验证。比如到数据库中取用户数据核对等等。

以这个登录验证类为例,我们可以书写其他过滤器来对表单输入做更加多的判断,增添更多的流程。如实现权限控制等等。

过滤器在web中设置,filterMapping键可以控制你的过滤器作用到那些uri。

由于过滤器有能力访问HttpServletRequest,HttpServletResponse, 因此有了他,你可以对用户的操作response.sendRedirect或者

hreq.getRequestDispatcher(url).forward(request, respoonse),以此来达到改变用户操作的目的。

当然你也可以在request中加入新的属性,以便被链上的jsp使用。

要注意的是每个过滤器在Web Server中只加载一次,所以不要在他的属性里面存储request,或

session域的东西。

整个源代码8.6k,用eclipse导入,就可以运行了。

这个实例的功能就是当访问网站的任何页面时(除login.jsp本身),如果用户没有登陆,就转登陆页面

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值