如何使用filter进行权限验证?

简介: 如何使用filter进行权限验证?

要使用过滤器(Filter)进行权限验证,需要创建一个自定义的过滤器类,实现javax.servlet.Filter接口,并在web.xml或通过注解进行配置

下面将以一个简单示例说明如何使用过滤器进行权限验证,该示例中会检查请求头中是否包含有效的令牌(token),如果没有,将返回未授权的错误信息。

  1. 创建过滤器类

    • 实现 Filter 接口:创建一个名为 AuthenticationFilter 的类并实现 Filter 接口。在 doFilter 方法中编写权限验证的逻辑[^1^][^2^]。

      import javax.servlet.Filter;
      import javax.servlet.FilterChain;
      import javax.servlet.ServletException;
      import javax.servlet.ServletRequest;
      import javax.servlet.ServletResponse;
      import javax.servlet.annotation.WebFilter;
      import java.io.IOException;
      
      @WebFilter(filterName = "AuthenticationFilter", urlPatterns = {
             "/adminService/*", "/otherService/*"})
      public class AuthenticationFilter implements Filter {
             
          public void init(FilterConfig filterConfig) throws ServletException {
             
              System.out.println("AuthenticationFilter-->init()");
          }
      
          public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
             
              HttpServletRequest httpRequest = (HttpServletRequest) request;
              HttpServletResponse httpResponse = (HttpServletResponse) response;
              // 获取请求URI
              String requestURI = httpRequest.getRequestURI();
              if (isIgnoreUri(requestURI)) {
             
                  chain.doFilter(httpRequest, httpResponse);
              } else {
             
                  // 从HTTP请求头中取出token
                  String token = httpRequest.getHeader("token");
                  if (isTokenEmpty(token)) {
             
                      handleUnauthorized(httpResponse);
                  } else {
             
                      verifyToken(token, httpResponse);
                  }
              }
          }
      
          private boolean isIgnoreUri(String uri) {
             
              // 指定不需要验证的URI列表
              List<String> ignoreUrls = Arrays.asList("/adminService/auth/token", "/adminService/auth/refreshToken");
              return ignoreUrls.contains(uri);
          }
      
          private boolean isTokenEmpty(String token) {
             
              return token == null || token.isEmpty();
          }
      
          private void handleUnauthorized(HttpServletResponse response) throws IOException {
             
              response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
              response.getWriter().write("{\"message\":\"Unauthorized\",\"code\":401}");
          }
      
          private void verifyToken(String token, HttpServletResponse response) {
             
              // 此处添加JWT或其他方式的token验证逻辑
              // 如果验证失败,可以使用handleUnauthorized方法处理响应
          }
      
          public void destroy() {
             
              // 清理资源
          }
      }
      
    • 初始化和销毁init 方法用于过滤器的初始化工作,例如资源加载,destroy 方法用于资源的清理工作。在本例中,这两个方法可以为空或打印初始化和销毁信息。
    • 过滤链:在 doFilter 方法中,首先判断当前请求的URI是否需要忽略权限验证,如果需要则直接放行。否则,从请求头中获取token并进行验证。如果token为空或无效,返回未授权错误信息;如果验证通过,则调用 chain.doFilter 继续后续处理。
  2. 配置过滤器
    • @WebFilter注解:使用 @WebFilter 注解来定义过滤器的名称和URL模式。在这个例子中,过滤器将拦截所有 /adminService/*/otherService/* 路径下的请求[^1^]。
      @WebFilter(filterName = "AuthenticationFilter", urlPatterns = {
             "/adminService/*", "/otherService/*"})
      
    • web.xml配置:如果不使用注解,可以在 web.xml 文件中配置过滤器和过滤规则。
      <filter>
          <filter-name>AuthenticationFilter</filter-name>
          <filter-class>com.example.AuthenticationFilter</filter-class>
      </filter>
      <filter-mapping>
          <filter-name>AuthenticationFilter</filter-name>
          <url-pattern>/adminService/*</url-pattern>
          <url-pattern>/otherService/*</url-pattern>
      </filter-mapping>
      
    • 忽略指定路径:可以通过 isIgnoreUri 方法指定某些路径不进行权限验证,直接放行。例如,登录和刷新token的请求通常不需要验证[^2^]。
  3. 验证Token
    • 获取请求头Token:从请求头中获取Token。如果Token不存在或为空,返回未授权错误信息[^1^][^2^]。
      String token = httpRequest.getHeader("token");
      if (isTokenEmpty(token)) {
             
          handleUnauthorized(httpResponse);
      }
      
    • 解析和校验Token:如果Token存在,需要进行解析和校验。这里可以结合JWT(Json Web Token)或其他方式进行Token的验证。如果验证失败,同样返回未授权错误信息[^1^][^2^]。
      if (!isTokenEmpty(token)) {
             
          verifyToken(token, httpResponse);
      }
      
    • 处理未授权响应:如果Token无效或解析失败,向客户端返回未授权的错误状态和消息。例如,设置HTTP状态码为401,并返回错误信息[^1^][^2^]。
      private void handleUnauthorized(HttpServletResponse response) throws IOException {
             
          response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
          response.getWriter().write("{\"message\":\"Unauthorized\",\"code\":401}");
      }
      
  4. 完整示例
    • 下面是一个完整的使用过滤器进行权限验证的示例,包括创建过滤器类、配置过滤器、获取并验证Token、处理未授权响应等步骤。具体实现时还需结合具体的业务场景和需求进行调整和优化[^1^][^2^][^3^][^4^]。

综上所述,通过使用过滤器进行权限验证,可以有效地控制对受保护资源的访问,提升应用的安全性。在实际项目中,过滤器常与其他技术如Spring Security、JWT等结合使用,以实现更复杂和全面的安全控制。

目录
相关文章
|
XML Java 应用服务中间件
Filter 过滤器--基本原理--Filter 过滤器生命周期--过滤器链--注意事项和细节--全部应用实例--综合代码示例
Filter 过滤器--基本原理--Filter 过滤器生命周期--过滤器链--注意事项和细节--全部应用实例--综合代码示例
199 0
|
存储 XML 消息中间件
filter功能演示-鉴权、声明缓存
filter功能演示-鉴权、声明缓存
171 0
|
小程序 前端开发 Java
java如何利用JWT和注解,自定义参数的方式优雅实现小程序用户Id管理
在我们的开发项目中,经常需要用到用户ID,比如在小程序商城系统中,我们将商品加入购物车,这时前端就需要发送请求,携带上用户的ID。基本上很多种请求操作都需要携带用户ID,如果每个请求都需要我们往data中添加id的话,那样需要写很多重复代码,并且代码也不美观;所以我们可以利用JWT跟注解的方式来实现;
205 0
|
Java
Filter概述、接口及配置
Filter概述、接口及配置
10782 0
|
JavaScript 前端开发 测试技术
loadrunner 脚本优化-关联函数web_reg_save_param()函数详解
loadrunner 脚本优化-关联函数web_reg_save_param()函数详解
247 0
【JavaWeb】简易权限校验、Filter-程序跳转
本期主要介绍简易权限校验、Filter-程序跳转
113 0
【JavaWeb】简易权限校验、Filter-程序跳转
|
存储 缓存 安全
还在亲手写Filter进行权限校验?尝试一下Shiro吧
还在亲手写Filter进行权限校验?尝试一下Shiro吧
118 0
还在亲手写Filter进行权限校验?尝试一下Shiro吧
|
存储 缓存 安全
01 还在手写filter进行权限校验?尝试一下Shiro吧
01 还在手写filter进行权限校验?尝试一下Shiro吧
159 0
01 还在手写filter进行权限校验?尝试一下Shiro吧
|
缓存 安全 JavaScript
极简权限认证必须掌握【代码+原理+建议收藏】
这个极简权限认证必须掌握,代码不过百,但是很关键
242 0
极简权限认证必须掌握【代码+原理+建议收藏】
|
网络安全
【SSH快速进阶】——struts2调用action的三种方式
经过前段时间对struts2的学习与实践,总结了一下在struts2中调用action的三种方式。