Spring学习笔记(9)——注入参数
集合类型属性
1.Set类型
- private Set<String> sets=new HashSet<String>();
- //我们需要给它添加set方法
- public Set<String> getSets()
- {
- return sets;
- }
- public void setSets(Set<String> sets)
- {
- this.sets = sets;
- }
- public Set<String> showSet()
- {
- return sets;
- }
然后根据属性修改配置文件
- <bean id="userService" class="com.szy.spring.service.UserServiceImpl">
- <property name="sets">
- <set>
- <value>Set1</value>
- <value>Set2</value>
- <value>Set3</value>
- </set>
- </property>
- </bean>
与以前不同的是我们在property下面添加了<set></set>
这样就能装配set类型的属性
2.List类型
List类型的属性和Set类型的方法一样,主要是把配置文件中的set修改成list。
- private List<String> lists=new ArrayList<String>();
- public List<String> getLists()
- {
- return lists;
- }
- public void setLists(List<String> lists)
- {
- this.lists = lists;
- }
- public List<String> showList()
- {
- return lists;
- }
配置文件修改如下
- <bean id="userService" class="com.szy.spring.service.UserServiceImpl">
- <property name="lists">
- <list>
- <value>List1</value>
- <value>List2</value>
- <value>List3</value>
- </list>
- </property>
- </bean>
3.Properties类型
- private Properties properties=new Properties();
- public void setProperties(Properties properties)
- {
- this.properties = properties;
- }
- public Properties getProperties()
- {
- return properties;
- }
- public Properties showProperties()
- {
- return properties;
- }
配置文件需要如下配置
- <bean id="userService" class="com.szy.spring.service.UserServiceImpl">
- <property name="properties">
- <props>
- <prop key="key1">Properties1</prop>
- <prop key="key2">Properties2</prop>
- <prop key="key3">Properties3</prop>
- </props>
- </property>
- </bean>
4.Map类型
- private Map<String, String> maps=new HashMap<String, String>();
- public List<String> getLists()
- {
- return lists;
- }
- public void setLists(List<String> lists)
- {
- this.lists = lists;
- }
- public Map<String, String> showMaps()
- {
- return maps;
- }
配置文件做相应的配置
- <bean id="userService" class="com.szy.spring.service.UserServiceImpl">
- lt;property name="maps">
- <map>
- <entry key="key1" value="Map1"></entry>
- <entry key="key2" value="Map2"></entry>
- <entry key="key3" value="Map3"></entry>
- </map>
- </property>
- </bean>
这样就完成了对Map类型的属性进行装配。
Spring完成自动扫描和管理bean
package com.szy.spring.service;
import org.springframework.stereotype.Service;
import com.szy.spring.dao.PersonDao;
@Service("service")
public class UserServiceImpl implements UserService
{
private PersonDao personDaoBean;
public void show()
{
personDaoBean.show();
}
public void setPersonDaoBean(PersonDao personDaoBean)
{
this.personDaoBean = personDaoBean;
}
}
在前面的例子中,都是使用XML的bean定义来使用组件,在大的项目中,通常会有上百个组件,如果这些组件采用xml的bean定义来配置,显然会使配置文件显得很臃肿,查找和维护起来不方便。Spring2.5为我们引入了组件自动扫描机制,它可以在类路径下寻找标记了@Component、@Service、@Controller、@Repository注解的类,并把这些类纳入到spring容器中管理,它的作用和在xml中使用bean节点配置组件一样。要使用自动扫描机制,我们需要把配置文件如下配置:
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
- http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
- <context:component-scan base-package="com.szy.spring"></context:component-scan>
- </beans>
其中base-package为需要扫描的包(包括子包)
@Service用于标注业务层的组件,@Controller用于标注控制层组件(如struts中的action),@Repository用于标注数据访问组件,即DAO组件,而@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。但是在目前的spring版本中,这几个注解的作用是一样的,但是在以后可能会进行区分。
下面把先前的例子修改一下:
首先是PersonDaoBean类,修改如下
- package com.szy.spring.dao;
- import org.springframework.stereotype.Repository;
- @Repository
- //告诉spring这个类要交给spring管理,
- public class PersonDaoBean implements PersonDao
- {
- public void show()
- {
- System.out.println("执行PersonDaoBean中的add()方法");
- }
- }
然后是UserServiceImpl类
- package com.szy.spring.service;
- import org.springframework.stereotype.Service;
- import com.szy.spring.dao.PersonDao;
- @Service
- //把这个类交给spring管理,作为服务了。
- public class UserServiceImpl implements UserService
- {
- private PersonDao personDaoBean;
- public void show()
- {
- personDaoBean.show();
- }
- public void setPersonDaoBean(PersonDao personDaoBean)
- {
- this.personDaoBean = personDaoBean;
- }
- public PersonDao getPersonDaoBean()
- {
- return personDaoBean;
- }
- }
下面我们进行测试,原来的测试代码是userServiceImpl
- ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
- UserService service=(UserService)ctx.getBean("userService");
- service.show();
其中userService是我们在配置文件中配置的bean的id。但是如今我们并没有id这个属性,在spring2.5中,默认的id是类的名称,但是开后是小写,也就是userServiceImpl,因此测试代码应修改如下:
- AbstractApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
- UserService service=(UserService)ctx.getBean("userServiceImpl");
- System.out.println(service);
如果我们想自己命名的话,则只需在注解后加上括号,里面写入你希望的名字,如
@Service("userService")。
在spring中默认的是之生成一个bean实例,如果我们想每次调用都产生一个实例,则标注需如下配置
@Service @Scope("prototype")
在xml中我们还可以配置初始化方法和销毁方法,使用标注后只需如下标注
- @PostConstruct
- public void init()
- {
- System.out.println("初始化");
- }
- @PreDestroy
- public void destory()
- {
- System.out.println("销毁");
- }
使用注解后,我们的xml文件变得十分简单,因此建议大家在以后的开发中使用注解。