在工具类中,直接使用注入的静态变量,及service接口

springboot 工具类中注入service接口,静态变量 java @PostConstruct_服务器

1.类上加入@Component注解

2.声明非静态变量,value注解对应springboot 配置文件中的变量  init中赋值给静态变量

                           注入service 

3.声明一个静态的本类

4.初始化, 声明一个void的方法,名字可以随意命名,例如:init() 

加上注解 @PostConstruct 

@PostConstruct基本:

@PostConstruct注解 是Java自己的注解。

Java中该注解的说明:@PostConstruct该注解被用来修饰一个非静态的void()方法。被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器执行一次。PostConstruct在构造函数之后执行,init()方法之前执行。

通常我们会是在Spring框架中使用到@PostConstruct注解 该注解的方法在整个Bean初始化中的执行顺序:

Constructor(构造方法) -> @Autowired(依赖注入) -> @PostConstruct(注释的方法)

应用场景

其实从依赖注入的字面意思就可以知道,要将对象p注入到对象a,那么首先就必须得生成对象p与对象a,才能执行注入。所以,如果一个类A中有个成员变量p被@Autowired注解,那么@Autowired注入是发生在A的构造方法执行完之后的。

如果想在生成对象时候完成某些初始化操作,而偏偏这些初始化操作又依赖于依赖注入,那么就无法在构造函数中实现。为此,可以使用@PostConstruct注解一个方法来完成初始化,@PostConstruct注解的方法将会在依赖注入完成后被自动调用。

Constructor >> @Autowired >> @PostConstruct

@PostConstruct说明

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

.@PreConstruct说明

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


@Component// 1 工具 注入到容器
public class WXXCXUtils {

     //静态变量
	public static String PaymentCallBack ;	

	// 2 注入非静态变量,后赋值给静态变量
	@Value("${weixin.global.paymentCallBack}")
	private String PaymentCallBackTemp;

    // 2 注入service
	@Autowired
	private IXcxDeployService xcxDeployService;

	//第三步 声明一个静态的本类
	private static WXXCXUtils wxxcxUtils;

	//第四步 初始化  -- 工具类先初始化, service 初始化, 最后 init
	@PostConstruct
	public void init(){
		wxxcxUtils = this;
		wxxcxUtils.xcxDeployService = this.xcxDeployService;
		PaymentCallBack = PaymentCallBackTemp;
	}
    public static void initWXXCXInfo(){

		 // 使用注入的静态service 
		  wxxcxUtils.xcxDeployService.selectXcxDeployByMap(pMap);		 
	}
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.