zoukankan      html  css  js  c++  java
  • @Value注入static属性

    一般@Value是使用在非静态方法上的

    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.stereotype.Component;
    
    @Component
    public class Test {
        @Value("${url}")
        public String url = "/dev/xx";
    }

    对于静态方法,以下做法是无效的

    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.stereotype.Component;
    
    @Component
    public class Test {
        @Value("${url}")
        public static String url = "/dev/xx";
    }

    需要使用如下方法

    方法一:xml通过bean注入

    方法二:使用set方法注入

    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.stereotype.Component;
    
    @Component
    public class Test {
        public static String url = "/dev/xx";
    
        @Value("${url}")
        public static void setUrl(String url) {
            Test.url = url;
        }
    }

    方法三:通过中间变量赋值

    import javax.annotation.PostConstruct;
    
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.stereotype.Component;
    
    @Component
    public class Test {
        public static String url = "/dev/xx";
    
        @Value("${url}")
        public String tempUrl = "/dev/xx";
    
        @PostConstruct
        public void init() {
            url = tempUrl;
        }
    }

    1.@PostConstruct说明

         被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器调用一次,类似于Serclet的inti()方法。被@PostConstruct修饰的方法会在构造函数之后,init()方法之前运行。

    2.@PreConstruct说明

         被@PreConstruct修饰的方法会在服务器卸载Servlet的时候运行,并且只会被服务器调用一次,类似于Servlet的destroy()方法。被@PreConstruct修饰的方法会在destroy()方法之后运行,在Servlet被彻底卸载之前。(详见下面的程序实践)

  • 相关阅读:
    室内设计师招募中...
    winform控件部署于web中控件装载ie中
    Oracle10g在windows2003下双机热备安装
    购房风波(4)不了了之
    [原创]面向对象理解·抽象类和派生类理解和使用
    Infragistics NetAdvantage 2006 Volume 2 CLR 2.0曲折安装
    两个Javascript小tip
    PHP学习笔记之二
    C#开发语音机项目
    关于WebBrowser的DocumentText
  • 原文地址:https://www.cnblogs.com/xiang--liu/p/11445318.html
Copyright © 2011-2022 走看看