SpringBoot Filter 权限管理

一、通过Filter进行权限管理主要分为两部分:

在这里插入图片描述

1.Config:用于将Filter拦截器与接口路径进行绑定

2.interceptor:在拦截器与接口路径绑定的前提下,进行更加细致的拦截操作(比如判断某种情况是拦截还是放行)

二、具体代码

config: 用于将AdminFilter拦截器与路径/admin进行绑定

import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.Ordered;

@Configuration
public class FilterConfig {


    @Bean
    public FilterRegistrationBean<AdminFilter> adminFilterFilterRegistrationBean() {
        FilterRegistrationBean<AdminFilter> filterRegBean = new FilterRegistrationBean<>();
        filterRegBean.setFilter(new AdminFilter());
        filterRegBean.addUrlPatterns("/admin/*");
        filterRegBean.setOrder(Ordered.LOWEST_PRECEDENCE -2);
        return filterRegBean;
    }
    
}

interceptor:拦截细致化操作

import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Component
public class AdminFilter implements Filter {
    
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {

        //校验用户登陆状态
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;

        //Filter过滤器跨域处理
        response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));        // 响应标头指定 指定可以访问资源的URI路径
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, OPTIONS, DELETE");//响应标头指定响应访问所述资源到时允许的一种或多种方法
        response.setHeader("Access-Control-Max-Age", "3600");                                 //设置 缓存可以生存的最大秒数
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with");               //设置  受支持请求标头
        response.setHeader("Access-Control-Allow-Credentials","true");                        // 指示的请求的响应是否可以暴露于该页面。当true值返回时它可以被暴露
        
        //这边举个例子,如果满足某个条件则放行
        if(request != null) {

            //使用者是管理员则放行
            filterChain.doFilter(servletRequest, servletResponse);
        }
    }
}

Controller中的路径:

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
回答: 在Spring Boot中使用Filter可以通过以下步骤进行操作。首先,了解过滤器(Filter)的概念,它是Servlet技术中最实用的技术之一,可以在客户端和服务器之间起到过滤作用,过滤掉一些不符合要求的请求。常见的应用场景包括会话校验、权限判断、敏感词汇过滤等。\[2\]在Spring Boot中使用Filter需要引入Spring Boot的基础依赖,并创建自己的过滤器。过滤器需要实现Filter接口,并重写其中的三个方法:init、doFilter和destroy。init方法在过滤器实例化后只会被调用一次,用于初始化过滤器;doFilter方法在每次请求通过过滤器链时被调用,用于对请求进行处理;destroy方法在Web容器停止服务时被调用,用于清理资源。\[3\]通过以上步骤,就可以在Spring Boot中使用Filter了。 #### 引用[.reference_title] - *1* *3* [springboot中使用filter过滤器](https://blog.csdn.net/pky86676022/article/details/129014505)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [SpringBoot--Filter过滤器(一)](https://blog.csdn.net/weixin_51110874/article/details/123319236)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大可iii

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值