1、在new出来的对象中,Spring无法自动注入对象
直接上代码
private UserDao userDao;
@Autowired
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
public boolean hasMatchUser(String userName, String password) {
int matchCount = userDao.getmatchCount(userName, password);②
return matchCount > 0;
}
---------------------------------------------------------
@Test
public void testHashMatchUser() {
UserService userService=new UserService();①
boolean b1 = userService.hasMatchUser("admin", "123456");
assertTrue(b1);
}
在测试跑这段代码的时候,我们会发现,通过①处new出来的对象,执行到②处时,会发现userDao为null,这个时候我们做了一系列检查,会发现任何问题,userDao对象也已经存在于Spring容器中。原来,使用new创建对象之后,UserService类并不受Spring管理了,Spring的注解是在Spring实例化的时候扫描注入,在Spring实例化完毕之后如果在new新的对象显然不受Spring管理了。如果想解决此问题,一种是按如下代码操作
private UserService userService;
@Autowired
public void setUserService(UserService userService) {
this.userService = userService;
}
@Test
public void testHashMatchUser() {
boolean b1 = userService.hasMatchUser("admin", "123456");
assertTrue(b1);
}
还有种就是直接从Spring池中取出userDao,而不是通过 @Autowired自动注入。
直接从Spring池中取出Bean对象有很多方式,这里列出下面一种:
public class SpringUtil implements ApplicationContextAware {
private static ApplicationContext applicationContext = null;
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
if (SpringUtil.applicationContext == null) {
SpringUtil.applicationContext = applicationContext;
System.out.println("--------------------------------------------------------");
System.out.println("========ApplicationContext配置成功,applicationContext=" + applicationContext + "========");
System.out.println("--------------------------------------------------------");
}
}
public static ApplicationContext getApplicationContext() {
return applicationContext;
}
// 通过name获取Bean
public static Object getBean(String name) {
return getApplicationContext().getBean(name);
}
// 通过class获取Bean
public static <T> T getBean(Class<T> clazz) {
return getApplicationContext().getBean(clazz);
}
// 通过name,class获取Bean
public static <T> T getBean(String name, Class<T> clazz) {
return getApplicationContext().getBean(name, clazz);
}
}
2、关于在多工程下多个属性加载器的使用
经常会遇到在多个工程中,我们又不同的属性文件需要分别加载使用。
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
p:location="classpath:application.properties" p:fileEncoding="utf-8"/>
一般我们都是如上方式使用,但是这是在单配置文件情况下使用。对于多配置文件,这样会失败,后加载的会覆盖先加载的。因此,我们需要加两个参数
p:order="1" p:ignoreUnresolvablePlaceholders="true"
其中order属性代表其加载顺序,而ignoreUnresolvablePlaceholders为是否忽略不可解析的 Placeholder,如配置了多个PropertyPlaceholderConfigurer,则需设置为true。这里一定需要按照这种方式设置这两个参数。