在Java Filter 中注入 Service方案一

本文介绍了如何在Java Filter中实现Service的注入,通过创建辅助类并进行web.xml配置,结合具体的java代码展示了详细的实现步骤。

新建一个类

package com.fulihui.yiyuanservice.common.util;

import javax.annotation.PostConstruct;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ApplicationObjectSupport;
import org.springframework.stereotype.Component;

/**
 * Spring ApplicationContext工具,类通过 {@link Component}注解注入到bean容器,
 * 初始化时调用init方法,将ApplicationContext赋值到静态变量instance上。
 * @author Created by Willard.Hu on 2016/8/12 0012.
 */
@Component
public class ApplicationContextUtil extends ApplicationObjectSupport {

    private static ApplicationContext instance;

    public static ApplicationContext getContext() {
        return instance;
    }

    @PostConstruct
    private void init() {
        instance = getApplicationContext();
    }

}

web.xml配置

 <!--配置过滤器-->
       <filter>
          <filter-name>AuthenticationLoginFliter</filter-name>
          <filter-class>com.fulihui.yiyuanservice.web.filter.AuthenticationLoginFliter</filter-class>
          <init-param>  
             <param-name>forceEncoding</param-name>  
             <param-value>true</param-value>  
          </init-param>  
          <init-param>  
             <param-name>encoding</param-name>  
             <param-value>UTF-8</param-value>  
          </init-param> 
      </filter>
<!--      映射过滤器 -->
      <filter-mapping>
          <filter-name>AuthenticationLoginFliter</filter-name>
         <!--  “/*”表示拦截所有的请求 -->
          <url-pattern>/*</url-pattern>
      </filter-mapping> 

java代码

package com.fulihui.yiyuanservice.web.filter;

import java.io.IOException;

import javax.inject.Inject;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationContext;


import com.fulihui.yiyuanservice.biz.shard.AuthBizManager;
import com.fulihui.yiyuanservice.common.util.AppConfig;
import com.fulihui.yiyuanservice.common.util.ApplicationContextUtil;
import com.fulihui.yiyuanservice.common.util.SessionContext;
import com.fulihui.yiyuanservice.common.util.SessionUtil;
import com.fulihui.yiyuanservice.domain.ExternalUser;
/**
 * 登陆认证 
 * @time 2016-9-30 10:50 
 * @author hongwang.zhang
 *
 */
public class AuthenticationLoginFliter implements Filter  {

    /* logger */
    private static final Logger log = LoggerFactory.getLogger(AuthenticationLoginFliter.class);


    private AuthBizManager      authBizManager;


    private AppConfig           appConfig;


    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        // TODO Auto-generated method stub
        ApplicationContext context = ApplicationContextUtil.getContext();
        appConfig = context.getBean(AppConfig.class);
        authBizManager = context.getBean(AuthBizManager.class);
        System.out.println("初始化 来咯。。。。。。。。。。。。。。");
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
                                                                                             throws IOException,
                                                                                             ServletException {

        try {
            HttpServletRequest  httpRequest=(HttpServletRequest)request; 
            HttpServletResponse httpResponse=(HttpServletResponse)response;

            SessionUtil.setSession(httpRequest.getSession());
            HttpSession session = httpRequest.getSession();
            String path = httpRequest.getServletPath();

            if (session.getAttribute("user") == null
                    || session.getAttribute("userId") == null){

                   //判断是否为拦截页面true 放行
                    if (!authBizManager.needAuth(path)) {
                        String userId = authBizManager.getUserId(httpRequest);
                        if(StringUtils.isNotEmpty(userId)){
                             ExternalUser user = authBizManager.getUserInfo(httpRequest, userId);
                        }else{

                            chain.doFilter(httpRequest, httpResponse);
                        }



                    } else {
                        String userId = authBizManager.getUserId(httpRequest);
                        if(StringUtils.isEmpty(userId)){
                            String redirect = authBizManager.getRedirectPath(httpRequest);
                            httpResponse.sendRedirect(redirect);
                        }else{
                             ExternalUser user = authBizManager.getUserInfo(httpRequest, userId);
                             if(user==null){
                                 Modeladnview(httpRequest,httpResponse);
                                 chain.doFilter(httpRequest, httpResponse);
                             }
                        }



                    }
            }else {
                Modeladnview(httpRequest,httpResponse);
                chain.doFilter(httpRequest, httpResponse);
              /*  // 获取信息
                String userId =session.getAttribute("userId")==null?"":session.getAttribute("userId").toString();
                ExternalUser user = authBizManager.getUserInfo(httpRequest,
                        userId);
                if(user==null){                 
                    Modeladnview(httpRequest,httpResponse);
                    chain.doFilter(httpRequest, httpResponse);
                }else{
                    Modeladnview(httpRequest,httpResponse);
                    chain.doFilter(httpRequest, httpResponse);
                }*/
            } 

           /* String userId = authBizManager.getUserId(httpRequest);
            if(StringUtils.isEmpty(userId)){
                String redirect = authBizManager.getRedirectPath(httpRequest);
                httpResponse.sendRedirect(redirect);
            }*/
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    public void Modeladnview(HttpServletRequest httpServletRequest,HttpServletResponse httpResponse){
        ExternalUser user = SessionContext.getExternalUser(httpServletRequest);
        String isLogin = null;
        if (user != null) {
            if (StringUtils.isEmpty(user.getUserId())) {
                isLogin = "0";
            } else {
                isLogin = "1";
            }
        } else {
            isLogin = "0";
        }
        httpServletRequest.setAttribute("isLogin", isLogin);
        httpServletRequest.setAttribute("curUser", user);
    }

    @Override
    public void destroy() {
        // TODO Auto-generated method stub

    }

    public static void main(String[] args) {
        System.out.println(StringUtils.isEmpty(null));
    }

}
在SSM(Spring + Spring MVC + MyBatis)项目中,有多种注入Service的方法: ### 注解方式 使用`@Autowired`、`@Resource`或`@Inject`注解可以方便地进行依赖注入。以`@Autowired`为例,在需要使用Service的类中,可以这样注入: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @Component public class SomeClass { @Autowired private UserService userService; // 其他代码 } ``` `@Resource`是JSR-250规范的注解,它可以根据名称或类型进行注入: ```java import javax.annotation.Resource; import org.springframework.stereotype.Component; @Component public class AnotherClass { @Resource(name = "userService") private UserService userService; // 其他代码 } ``` `@Inject`是JSR-330规范的注解,使用方式和`@Autowired`类似: ```java import javax.inject.Inject; import org.springframework.stereotype.Component; @Component public class ThirdClass { @Inject private UserService userService; // 其他代码 } ``` ### XML配置方式 在Spring的配置文件(如`applicationContext.xml`)中,可以通过`<bean>`标签进行注入: ```xml <bean id="someClass" class="com.example.SomeClass"> <property name="userService" ref="userService"/> </bean> <bean id="userService" class="com.example.service.impl.UserServiceImpl"/> ``` ### 在过滤器注入Service过滤器注入Service时,由于过滤器的初始化顺序问题,可能会导致注入失效。可以通过在`web.xml`中配置`DelegatingFilterProxy`来解决: ```xml <!-- 代理过滤器,用于在filter中使用serviceservice需在applicationContext.xml中单独配置 --> <filter> <filter-name>DelegatingFilterProxy</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> <init-param> <param-name>targetBeanName</param-name> <param-value>TFilter</param-value> </init-param> <init-param> <param-name>targetFilterLifecycle</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>DelegatingFilterProxy</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 这样配置后,过滤器会由Spring管理,从而可以正常注入Service [^3]。 ### 在Servlet中注入Service 在Servlet中注入Service,可以在`init`方法中使用`SpringBeanAutowiringSupport`: ```java import javax.servlet.ServletConfig; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import org.springframework.web.context.support.SpringBeanAutowiringSupport; public class MyServlet extends HttpServlet { @Override public void init(ServletConfig config) throws ServletException { super.init(config); SpringBeanAutowiringSupport.processInjectionBasedOnServletContext(this, config.getServletContext()); } // 其他代码 } ``` ### 在单元测试中注入Service 在单元测试类中注入Service,可以使用`@RunWith`和`@ContextConfiguration`注解: ```java import org.junit.runner.RunWith; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.web.WebAppConfiguration; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath:spring-config.xml") @WebAppConfiguration public class MyTest { // 测试代码 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值