使用Filter进行 过滤非法登录用户

            很多时候,我们都需要做用户登录和登录用户的权限管理,如何防止没登录系统的用户访问不该访问的页面呢?

第一种解决办法,在没个用户登录相关的页面中判定相应的session是否为空,系统比较小该方法还可行? 系统比较大呢?上千个页面呢?难道也要在每个页面中去判断吗?这或许不太可取

第二种,引入filter

 

具体实现如下:

 

我们在Action中,利用request.getSession().setAttribute("user",user);

并讲请求分发到scuess.jsp

 

scuess.jsp中无需做任何session就能判定用户是否非法登录

嘿嘿,别忘了,在web.xml中还需要配置;

 

  1.  <filter>
  2.     <filter-name>loginFilter</filter-name>
  3.     <filter-class>com.lovexx.tools.LoginFilter</filter-class>
  4. </filter>
  5.    
  6. <filter-mapping>
  7.  <filter-name>loginFilter</filter-name>
  8.  <url-pattern>/scuess.jsp</url-pattern>
  9. </filter-mapping>

忘和j2ee爱好者多多交流,共同进步

 

在struts开发中,对特定目录下的页面进行过滤的时候,要注意别对action path 相对路径的aciton.do进行验证,否则会出错,

如我的web.xml中的配置如下

  1. <filter>
  2.     <filter-name>loginFilter</filter-name>
  3.     <filter-class>com.zq.tools.LoginFilter</filter-class>
  4.     <init-param>
  5.         <param-name>undo</param-name>
  6.         <param-value>/index.jsp</param-value>       
  7.     </init-param>
  8.   </filter>
  9.   <filter-mapping>
  10.     <filter-name>loginFilter</filter-name>
  11.     <url-pattern>/company/*</url-pattern>
  12.   </filter-mapping>

而struts-config.xml中的配置如下

  1. <action
  2.       attribute="loginForm"
  3.       name="loginForm"
  4.       path="/company/login"
  5.       scope="request"
  6.       type="com.zq.struts.action.LoginAction">
  7.       <forward
  8.         name="scuess"
  9.         path="/company/main.jsp"
  10.         redirect="true" />
  11.       <forward
  12.         name="fail"
  13.         path="/index.jsp"
  14.         redirect="true" />
  15.     </action>

那么在过滤company目录下的资源时候,company/login.do也会进行过滤,如果此时不做处理,则会出现死循环的现象

 

我是这样做的,但好像还是有一点不合理

 

  1. public void doFilter(ServletRequest arg0, ServletResponse arg1,
  2.             FilterChain arg2) throws IOException, ServletException {
  3.         // TODO Auto-generated method stub
  4.         HttpServletRequest request = (HttpServletRequest) arg0;
  5.         HttpServletResponse response = (HttpServletResponse) arg1;
  6.         Object recored = request.getSession().getAttribute("info");
  7.         System.out.println(recored);
  8.         System.out.println(request.getRequestURI());
  9.         if (!request.getRequestURI().equals("/cdsoft/company/login.do")) {
  10.             if (recored == null) {
  11.                 response.sendRedirect("/index.jsp");
  12.                 
  13.             }
  14.         }
  15.         arg2.doFilter(arg0, arg1);
  16.     }

 

也可以在web.xml配置Filter初始化参数,在Filter中得到初始化参数,并进行处理

 

转载请注明出处

Author:Jack Zhang


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在JavaWeb中,可以使用Filter来实现用户自动过滤Filter是Servlet规范中的一种组件,它能够对请求和响应进行过滤和修改,可以用于实现各种功能,如用户自动过滤、字符编码转换、权限控制等。 下面是一个简单的用户自动过滤Filter的示例代码: ```java @WebFilter(filterName = "userFilter", urlPatterns = {"/*"}) public class UserFilter implements Filter { private List<String> blacklist = Arrays.asList("hack", "attack", "sql", "xss"); public void init(FilterConfig config) throws ServletException { // 初始化 } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) request; String uri = req.getRequestURI(); String method = req.getMethod(); if ("POST".equals(method) && uri.contains("user")) { String username = req.getParameter("username"); String password = req.getParameter("password"); if (checkBlacklist(username) || checkBlacklist(password)) { // 检测到黑名单,返回提示信息 response.getWriter().write("您的输入包含非法字符,已被系统拦截!"); return; } } chain.doFilter(request, response); } public void destroy() { // 销毁 } private boolean checkBlacklist(String input) { if (input == null || input.isEmpty()) { return false; } for (String str : blacklist) { if (input.contains(str)) { return true; } } return false; } } ``` 上述代码中,我们定义了一个名为UserFilterFilter,并将其配置为拦截所有请求(urlPatterns={"/*"})。在doFilter方法中,我们首先获取请求的URI和请求方法,如果是POST请求并且URI包含"user",则说明用户正在进行登录或注册操作,需要对用户名和密码进行校验。我们调用checkBlacklist方法来检查用户名和密码中是否包含黑名单中的关键词,如果包含,就直接返回提示信息,否则调用chain.doFilter方法将请求传递给下一个Filter或Servlet。checkBlacklist方法的实现与前面的示例相同,不再赘述。 需要注意的是,Filter必须在web.xml或使用注解@WebFilter进行注册和配置。在上述示例中,我们使用了注解@WebFilter来注册Filter,这需要在Web项目中使用Servlet 3.0或以上版本的容器才能生效。如果使用的是Servlet 2.5或以下版本的容器,就必须在web.xml中配置Filter,例如: ```xml <filter> <filter-name>userFilter</filter-name> <filter-class>com.example.UserFilter</filter-class> </filter> <filter-mapping> <filter-name>userFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 这样,我们就完成了一个简单的用户自动过滤Filter的实现。需要注意的是,这只是一个示例,实际应用中可能需要更加复杂和完善的校验机制,以确保系统的安全性和稳定性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值