随着jdk1.5引进注解功能后,使得注解越来越流行开来,各个开源框架纷纷提供了对注解的支持,其中Spring从3.0版本以后便提供了较为全面的注解支持,对于Spring大行其道的今天,掌握新技术对于自身成长来说是非常有利的。今天笔者就此总结分享给大家。
一、IOC容器
IOC是Spring的核心技术,以前一直都是以XML的方式来配置的,现在能利用注解简化配置的方式。实例如下:
action层:
package com.action; import javax.annotation.Resource; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Controller; import com.entity.Student; import com.opensymphony.xwork2.ActionSupport; import com.service.IStudentService; @Controller("StudentAction") @Scope("prototype") public class StudentAction extends ActionSupport { private static final long serialVersionUID = -1523904052147405750L; private Student student; @Resource(name="studentService2") private IStudentService studentService; @Override public String execute() throws Exception { String id = studentService.insert(student); System.out.println(id); return "success"; } public Student getStudent() { return student; } public void setStudent(Student student) { this.student = student; } }
service层:
package com.service.impl; import javax.annotation.Resource; import org.springframework.stereotype.Service; import com.dao.IStudentDao; import com.entity.Student; import com.service.IStudentService; @Service public class StudentService implements IStudentService { @Resource private IStudentDao studentDao; @Override public String insert(Student student) { String id = studentDao.insert(student); return id; } }
dao层:
package com.dao.jdbc.impl; import javax.annotation.Resource; import org.springframework.jdbc.core.namedparam.BeanPropertySqlParameterSource; import org.springframework.jdbc.core.namedparam.NamedParameterJdbcDaoSupport; import org.springframework.jdbc.core.namedparam.SqlParameterSource; import org.springframework.jdbc.support.GeneratedKeyHolder; import org.springframework.jdbc.support.KeyHolder; import org.springframework.stereotype.Repository; import com.dao.IStudentDao; import com.util.SQLUtils; import com.util.SqlType; @Repository public class StudentDao implements IStudentDao { @Resource private NamedParameterJdbcDaoSupport namedParameterJdbcDaoSupport; @Override public <T> String insert(T t) { String sql = SQLUtils.getSql(t.getClass(), SqlType.INSERT); KeyHolder keyHolder = new GeneratedKeyHolder(); SqlParameterSource paramSource = new BeanPropertySqlParameterSource(t); namedParameterJdbcDaoSupport.getNamedParameterJdbcTemplate().update(sql, paramSource, keyHolder, new String[] { "id" }); return keyHolder.getKeys().get("id").toString(); } }
struts.xml:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <constant name="struts.objectFactory" value="spring" /> <package name="struts" namespace="" extends="struts-default"> <action name="student" class="StudentAction"> <result name="success">/success.jsp</result> </action> </package> </struts>
applicationContext.xml:
<?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:aop="http://www.springframework.org/schema/aop" 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-3.1.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd"> <context:annotation-config /> <context:component-scan base-package="com.action,com.dao,com.service,com.servlet" /> <aop:aspectj-autoproxy /> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" /> <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl" /> <property name="username" value="wang" /> <property name="password" value="wang" /> </bean> <bean id="namedParameterJdbcDaoSupport" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcDaoSupport"> <property name="dataSource" ref="dataSource" /> </bean> <bean id="jdbcTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <aop:config> <aop:pointcut id="allManagerMethod" expression="execution(* com.dao.*.*(..))"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="allManagerMethod"/> </aop:config> <tx:advice id="txAdvice" transaction-manager="jdbcTransactionManager"> <tx:attributes> <tx:method name="insert*"/> <tx:method name="save*"/> <tx:method name="update*"/> <tx:method name="delete*"/> <tx:method name="find*" read-only="true"/> <tx:method name="*" read-only="true"/> </tx:attributes> </tx:advice> </beans>
web.xml:
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>sshAnotation</display-name> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:com/config/applicationContext.xml</param-value> </context-param> <filter> <filter-name>struts</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> <init-param> <param-name>config</param-name> <param-value>struts-default.xml,struts-plugin.xml,/com/config/struts.xml</param-value> </init-param> </filter> <filter-mapping> <filter-name>struts</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <welcome-file-list> <welcome-file>index.jsp</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> </web-app>
通过以上实例我们可以观察出,applicationContext.xml配置文件中已经没有以前配置的业务bean(如studentDao)了,取而代之的是写在代码里的@Controller、@Service、@Repository和@Resource,那么他们各代表什么意义呢?
@Controller、@Service、@Repository是在@Component基础上拓展而来,它们分别对应表现层Bean,业务层Bean ,和数据层Bean,他们除了语义上不同之外,本质和用法上没有什么区别,。而@Component以过时不推荐使用。
@Resource其实与@Autowired的作用相似,都是代替<property>标签来注入对象的,但推荐使用@Resource。
@Scope是用来设定Bean的生命周期的。
除了上述常用的之外,其他的还有@Lazy、@DependsOn、@PostConstruct、@PreDestroy等其他的注解,作用分别是:延迟初始化、依赖其他Bea、初始化方法、析构方法。
注解@标识放置的代码位置不是随意的,根据jdk1.5规范,要求注解写在类、接口、属性(成员变量)、方法、构造函数或方法参数上。不同的注解,可放置的位置也不同。例如上述:@Controller、@Service、@Repository、@Scope、@Lazy、@DependsOn都只能放在类上;@Resource、@Autowired能放在属性、方法、构造函数上;@PostConstruct、@PreDestroy则只能放在方法上
要想使用Spring注解,必须要在applicationContext.xml中配置<context:annotation-config>和<context:component-scan>这两个标签,前者用来告诉Spring要启用注解,后者则用来告诉Spring注解所在的包,以便Spring启动时扫描包并进行注入。
其实自Spring3.0以后IOC的Bean常用XML配置方式基本都有对应的注解方式,只不过另外的都不太常用,笔者了解的也不多,所以就不叙述了。
那么在这基础之上,我再为大家扩充点:1,、项目层次多于三层。2、一个接口多个实现类
1、项目层次多于三层
我们知道Spring就主流三层架构给出了@Controller、@Service、@Repository来对应,但如果项目中是多层(如action、servlet、service、dao)怎么办呢?其实@Service并不仅仅就局限于一层,我们可以在service层上用,同样可以在servlet层上用,例如:
servlet层:
package com.servlet.impl; import javax.annotation.Resource; import org.springframework.stereotype.Service; import com.entity.Student; import com.service.IStudentService; import com.servlet.IStudentServlet; @Service public class StudentServlet implements IStudentServlet { @Resource private IStudentService studentService; @Override public String insert(Student student) { return studentService.insert(student); } }
action层中只需将原先IStudentService的属性改为IStudentSerlet即可。
2、一个接口多个实现类
其实每个注解都是有参数可以指定的【如实例中:@Controller("StudentAction")】,如果不指定参数【即@Controller】,Spring默认则根据命名的名称来查找注入。如果指定了则根据的参数进行注入。一个接口有多个实现类,我们则可以通过@Resource(name="studentService2")来区分。
好了,本篇博文就IOC的注解方式进行了讲解,下一篇我们会继续介绍AOP和事务的注解方式。