zoukankan      html  css  js  c++  java
  • SpringContextUtil spring上下文获取工具类

    package com.midea.biz;
    
    import org.springframework.beans.BeansException;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.ApplicationContextAware;
    import org.springframework.util.Assert;
    
    public class SpringContextUtil implements ApplicationContextAware{
        
         private static ApplicationContext applicationContext;
         
            /**
             * 实现ApplicationContextAware接口的context注入函数, 将其存入静态变量.
             */
            @Override
            public void setApplicationContext(ApplicationContext applicationContext)
                    throws BeansException {
                SpringContextUtil.applicationContext = applicationContext;
            }
         
            /**
             * 取得存储在静态变量中的ApplicationContext.
             */
            public static ApplicationContext getContext() {
                checkApplicationContext();
                return applicationContext;
            }
         
            /**
             * 从静态变量ApplicationContext中取得Bean, 自动转型为所赋值对象的类型.
             */
            @SuppressWarnings("unchecked")
            public static <T> T getBean(String name) {
                checkApplicationContext();
                return (T) applicationContext.getBean(name);
            }
         
            /**
             * 从静态变量ApplicationContext中取得Bean, 自动转型为所赋值对象的类型.
             */
            @SuppressWarnings("unchecked")
            public static <T> T getBean(Class<T> clazz) {
                checkApplicationContext();
                return (T) applicationContext.getBeansOfType(clazz);
            }
         
            private static void checkApplicationContext() {
                Assert.notNull(applicationContext,
                        "applicaitonContext未注入,请在applicationContext.xml中定义SpringContextUtil");
            }
    
    }
  • 相关阅读:
    二叉链表(双叉链表)实现二叉树
    队列知识
    windows下Anaconda3配置TensorFlow深度学习库
    栈的顺序结构和链式结构实现
    Anaconda中配置Pyspark的Spark开发环境
    Scala学习笔记(3)-表达式归纳
    SparkR-Install
    推荐系统之最小二乘法ALS的Spark实现
    linux查看主机端口进程命令
    使用redis的五个注意事项
  • 原文地址:https://www.cnblogs.com/yun965861480/p/6553432.html
Copyright © 2011-2022 走看看