过滤器里面实现调用server服务

项目背景是使用springboot做开发,中间要做一层验证,因此打算使用filter中去做一个拦截验证

废话不多说,直接上代码

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.context.support.WebApplicationContextUtils;
import org.springframework.web.context.support.XmlWebApplicationContext;

import com.alibaba.fastjson.JSONObject;
import com.pactera.vds.mobile.service.UserService;

public class LoginFilter implements Filter {

    private UserService userservice;

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        ServletContext sct = filterConfig.getServletContext();
        XmlWebApplicationContext cxt = (XmlWebApplicationContext) WebApplicationContextUtils
                .getWebApplicationContext(sct);
        if (cxt != null && cxt.getBean("userservice") != null && userservice == null) {
            userservice = (UserService) cxt.getBean("userservice");
        }
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        HttpServletRequest req = (HttpServletRequest) request;
        HttpServletResponse resp = (HttpServletResponse) response;
        JSONObject json = (JSONObject) req.getSession().getAttribute("user");
        if (json == null || json.isEmpty()) {
            if (req.getRequestURI().contains("/sign/rz") || req.getRequestURI().contains("/sign/wxLogin")
                    || req.getRequestURI().contains("/sign/callBack") || req.getRequestURI().contains("/sign/sendSms")
                    || req.getRequestURI().contains("/sign/register")) {// 初次登陆请求中没有,放行
                chain.doFilter(request, response);
            } else {
                resp.sendRedirect("http://bmp.bofide.com/qd/binding");
            }
        } else {
            chain.doFilter(request, response);
        }
    }

    @Override
    public void destroy() {
    }

}

拦截器项目初始化时候直接使用init方法进行加载bean对象,如果通过@Autowired注入的server在filter中使用的时候会报空,因为还没有注入bean容器,这时就要求我们提前手动加载。用以上形式就可以完美解决,同理用这样的方式还可以提前注入自己享用的bean对象。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WebFlux是Spring Framework 5及以上版本中引入的一种响应式编程框架,用于构建高性能、可扩展的Web应用程序。在WebFlux中,过滤器(Filter)是一种可用于在请求和响应之间执行预处理和后处理逻辑的组件。 在WebFlux中,过滤器可以通过实现`org.springframework.web.server.WebFilter`接口来定义。该接口包含一个`filter`方法,用于在请求处理链上执行过滤逻辑。 以下是一个使用WebFlux过滤器的示例: ```java import org.springframework.http.HttpStatus; import org.springframework.stereotype.Component; import org.springframework.web.server.ServerWebExchange; import org.springframework.web.server.WebFilter; import org.springframework.web.server.WebFilterChain; import reactor.core.publisher.Mono; @Component public class MyFilter implements WebFilter { @Override public Mono<Void> filter(ServerWebExchange exchange, WebFilterChain chain) { // 在请求处理之前执行的逻辑 System.out.println("Before handling request"); // 调用下一个过滤器或处理器 return chain.filter(exchange).then(Mono.fromRunnable(() -> { // 在请求处理之后执行的逻辑 System.out.println("After handling request"); })); } } ``` 在上面的示例中,`MyFilter`类实现了`WebFilter`接口,并重写了`filter`方法。在该方法中,可以编写在请求处理前后需要执行的逻辑。通过调用`chain.filter(exchange)`方法,可以将请求传递给下一个过滤器或处理器。在`then`方法中,可以编写在请求处理后需要执行的逻辑。 需要注意的是,过滤器在`@Component`注解的类中定义,并且需要被Spring容器扫描到以生效。另外,可以通过使用`@Order`注解来指定过滤器的执行顺序。 以上是关于WebFlux过滤器的简单介绍,如果你有其他问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值