Filter过滤器实现权限控制

在操作中经常性的要对用户是否登陆进行验证,那么如果要进行验证的话,则肯定有大量的代码要不断的判断session是否存在。那么此种代码实际上就可以直接放在过滤器中进行编写。

登录页面:Login.jsp

  1. <script type="text/javascript">  
  2.    //检查是否输入用户名  否则不予提交    
  3.    function check(){  
  4.        var username = document.getElementById("username").value;  
  5.        if(username==null||""==username){  
  6.            alert("请输入用户名");  
  7.            return false;  
  8.        }  
  9.        return true;  
  10.    }  
  11.      
  12. </script>  
  13.     
  14.   <body>  
  15.        <center>  
  16.           <form action="loginServlet" method="post" onsubmit="return check()">  
  17.              <table>  
  18.                  <caption>用户登录</caption>  
  19.                  <tr>  
  20.                     <td>用户名</td><td><input type="text" id="username" name="username" /></td>  
  21.                  </tr>  
  22.                  <tr>  
  23.                     <td>密码</td><td><input type="text" name="password"/></td>  
  24.                  </tr>  
  25.                  <tr>  
  26.                     <td align="right" colspan="2"><input type="submit" value="登录"></td>  
  27.                  </tr>  
  28.              </table>  
  29.           </form>  
  30.        </center>  
  31.   </body>  

权限控制 用户其实就只有一个入口,即首先进行登录,登录后将信息保存在session中,如果session中没有内容,则无法进入其他页面或进行其他操作。

点击登录按钮 进入loginServlet将信息保存。

LoginServlet.java

  1. package com.org;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5.   
  6. import javax.servlet.ServletException;  
  7. import javax.servlet.http.HttpServlet;  
  8. import javax.servlet.http.HttpServletRequest;  
  9. import javax.servlet.http.HttpServletResponse;  
  10. import javax.servlet.http.HttpSession;  
  11.   
  12. public class LoginServlet extends HttpServlet {  
  13.   
  14.       
  15.     public void doGet(HttpServletRequest request, HttpServletResponse response)  
  16.             throws ServletException, IOException {  
  17.   
  18.         response.setContentType("text/html;charset=gbk");  
  19.         request.setCharacterEncoding("gbk");  
  20.         PrintWriter out = response.getWriter();  
  21.           
  22.         String username = request.getParameter("username");  
  23.         HttpSession session = request.getSession();  
  24.         session.setAttribute("username", username);  //用户登录加入到session中  
  25.           
  26.         response.sendRedirect("jsp/success.jsp");    //登录成功 跳入success.jsp  
  27.           
  28.         //测试   
  29.         System.out.println("username: "+username);  
  30.           
  31.         out.flush();  
  32.         out.close();  
  33.     }  
  34.   
  35.     public void doPost(HttpServletRequest request, HttpServletResponse response)  
  36.             throws ServletException, IOException {  
  37.   
  38.         this.doGet(request, response);  
  39.     }  
  40.   
  41. }  

Filter 拦截器: MyFilter.java

  1. package com.org;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import java.io.UnsupportedEncodingException;  
  6.   
  7. import javax.servlet.Filter;  
  8. import javax.servlet.FilterChain;  
  9. import javax.servlet.FilterConfig;  
  10. import javax.servlet.ServletException;  
  11. import javax.servlet.ServletRequest;  
  12. import javax.servlet.ServletResponse;  
  13. import javax.servlet.http.HttpServletRequest;  
  14. import javax.servlet.http.HttpServletResponse;  
  15. import javax.servlet.http.HttpSession;  
  16.   
  17. public class MyFilter implements Filter {  
  18.   
  19.     public void destroy() {  
  20.     }  
  21.   
  22.     public void doFilter(ServletRequest servletRequest,  
  23.             ServletResponse servletResponse, FilterChain filterChain)  
  24.             throws IOException, ServletException {  
  25.   
  26.         HttpServletRequest req = (HttpServletRequest) servletRequest;  
  27.         HttpSession session = req.getSession();  
  28.           
  29.         String username = (String)session.getAttribute("username");  
  30.           
  31.         if (username != null&&username!="") {  
  32.             // 如果现在存在了session,则请求向下继续传递  
  33.             filterChain.doFilter(servletRequest, servletResponse);  
  34.         } else {  
  35.             // 跳转到提示登陆页面  
  36.             servletRequest.getRequestDispatcher("/error.jsp").forward(servletRequest, servletResponse);  
  37.         }  
  38.     }  
  39.   
  40.     public void init(FilterConfig filterConfig) throws ServletException {  
  41.     }  
  42. }  

Filter从session中取出数据 看是否已登录,如果session中有内容 则执行 filterChain.doFilter()方法 请求继续向下传递。否则返回登录页面。

为了测试 还要有一个让其Session失效的类

InvalidateServlet.java

  1. package com.org;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5.   
  6. import javax.servlet.ServletException;  
  7. import javax.servlet.http.HttpServlet;  
  8. import javax.servlet.http.HttpServletRequest;  
  9. import javax.servlet.http.HttpServletResponse;  
  10. import javax.servlet.http.HttpSession;  
  11.   
  12. public class InvalidateServlet extends HttpServlet {  
  13.   
  14.       
  15.     public void doGet(HttpServletRequest request, HttpServletResponse response)  
  16.             throws ServletException, IOException {  
  17.   
  18.         response.setContentType("text/html;charset=gbk");  
  19.         request.setCharacterEncoding("gbk");  
  20.         PrintWriter out = response.getWriter();  
  21.         HttpSession session =request.getSession(); //得到session对象  
  22.         session.invalidate();                      //注销session  使其失效  
  23.         //然后跳转到登录页面  
  24.         request.getRequestDispatcher("/login.jsp").forward(request, response);  
  25.         out.flush();  
  26.         out.close();  
  27.     }  
  28.   
  29.     public void doPost(HttpServletRequest request, HttpServletResponse response)  
  30.             throws ServletException, IOException {  
  31.   
  32.           
  33.     }  
  34.   
  35. }  

如果在未登录时访问其他页面 则跳转到error.jsp页面

  1. <body>  
  2.         <center>  
  3.             <h3>  
  4.                 您还未登录,请先进行<a href="login.jsp">登录</a>  
  5.             </h3>  
  6.         </center>  
  7.     </body>  

登录成功页面 success.jsp

  1. <body>  
  2.         <center>  
  3.             欢迎<%=session.getAttribute("username")%>光临  
  4.             <br>  
  5.             <a href="invalidateServlet">退出</a>  
  6.         </center>  
  7.     </body>  

此外最好需要几个测试页面

test1.jsp  test2.jsp 里面随便一些显示内容即可

配置web.xml实现拦截

  1. <filter>  
  2.         <filter-name>myfilter</filter-name>  
  3.         <filter-class>com.org.MyFilter</filter-class>  
  4.     </filter>  
  5.     <filter-mapping>  
  6.         <filter-name>myfilter</filter-name>  
  7.         <url-pattern>/jsp/*</url-pattern>  
  8.     </filter-mapping>  
  9.       
  10.     <servlet>  
  11.         <servlet-name>LoginServlet</servlet-name>  
  12.         <servlet-class>com.org.LoginServlet</servlet-class>  
  13.     </servlet>  
  14.   <servlet>  
  15.     <servlet-name>InvalidateServlet</servlet-name>  
  16.     <servlet-class>com.org.InvalidateServlet</servlet-class>  
  17.   </servlet>  
  18.   
  19.     <servlet-mapping>  
  20.         <servlet-name>LoginServlet</servlet-name>  
  21.         <url-pattern>/loginServlet</url-pattern>  
  22.     </servlet-mapping>  
  23.   <servlet-mapping>  
  24.     <servlet-name>InvalidateServlet</servlet-name>  
  25.     <url-pattern>/invalidateServlet</url-pattern>     
  26.   </servlet-mapping>  
  27.     <welcome-file-list>  
  28.         <welcome-file>index.jsp</welcome-file>  
  29.     </welcome-file-list>  

除login.jsp在webroot目录下  其余jsp页面在jsp文件夹下

可进行如下方法的测试

不先进入login.jsp进行登录 访问 http://localhost:8080/filter/jsp/test1.jsp 则提示尚未登录。

然后进行登录 随便输入一个用户名,再访问test1.jsp 则可以进入 或者关闭浏览器重新打开,还是可以进入

直至在success.jsp页面中进行注销 。




  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值