10.1简介
注释配置相对于 XML 配置具有很多的优势:
(1)它可以充分利用 Java 的反射机制获取类结构信息,这些信息可以有效减少配置的工作。如使用 JPA 注释配置 ORM 映射时,我们就不需要指定 PO 的属性名、类型等信息,如果关系表字段和 PO 属性名、类型都一致,您甚至无需编写任务属性映射信息——因为这些信息都可以通过 Java 反射机制获取。
(2)注释和 Java 代码位于一个文件中,而 XML 配置采用独立的配置文件,大多数配置信息在程序开发完成后都不会调整,如果配置信息和 Java 代码放在一起,有助于增强程序的内聚性。而采用独立的 XML 配置文件,程序员在编写一个功能时,往往需要在程序文件和配置文件中不停切换,这种思维上的不连贯会降低开发效率。
因此在很多情况下,注释配置比 XML 配置更受欢迎,注释配置有进一步流行的趋势。但是大量使用注解会影响项目后期维护,因为只要改了一点点配置,就要修改源代码,整个项目需要重新编译再上线。那么,到底是使用注释配置还是XML 配置呢?这就要取决于整个项目的取舍。
10.2 开发环境
开发工具:myeclipse8.6.1
数据库:mysql5.5.23
服务器: tomcat6.0.37
框架版本: spring3.2.2
10.3 案例开发步骤
步骤一:在myeclipse8.6中新建web工程springmvc10,拷贝如下包到lib目下:
步骤二:编写web.xml 配置文件,代码如下:
=================================web.xml========================
<?xmlversion="1.0" encoding="UTF-8"?>
<web-appversion="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<!-- 配置spring的字符集过滤 -->
<filter>
<filter-name>encode</filter-name>
<filter-class>org.springframework.web.filter
.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encode</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>
================================================================
步骤三:建立index.jsp,和display.jsp,如下所示:
=========================index.jsp==============================
<body>
<h1><a href="hello.do">点击我</a></h1>
<!-- post方式被control中的注解限制了 -->
<form action="hello.do"name="myFrm" method="get">
<p><input type="submit" value="提交"/></p>
</form>
</body>
====================================================================
=========================hello.jsp==============================
<body>
<h1>查看信息:${requestScope.msg}</h1>
</body>
=====================================================================
步骤四:在com.wx.controls包下面编写控制器SimpleAnnotationControl.java,如下:
==================SimpleAnnotationControl.java======================
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class SimpleAnnotationControl {
@RequestMapping(value="/hello.do",method=RequestMethod.GET)
public ModelAndView show(){
ModelAndView mav=new ModelAndView("hello");
mav.addObject("msg", "hellojava");
return mav;
}
}
==================================================================
步骤五:在核心配置文件springmvc-servlet.xml里面完善如下配置
======================== springmvc-servlet.xml=======================
<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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<!-- 配置自动扫描 -->
<context:component-scan base-package="com.wx.controls"></context:component-scan>
<bean id="irvResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
====================================================================
知识讲解:在spring中,通过配置一个自动扫描器,可以自动扫描到某个范围下的所有组件,这些组件必须是标记有特定注解,比较常用的特定注解有@Component、@Repository、@Service和@Controller。比如这里就会把SimpleAnnotationControl类纳入spring容器管理。关于spring自动扫描管理bean可以参它的相关文档。
注解说明: @Repository用于注解dao层,配置一个dao实例
@Service用于注解service层,配置一个service实例
@Controller用于注解control层,配置一个control层实例
@ Component,所以bean实例都可以用它注解
@RequestMapping注解用于地址映射。在本例中,我们使用了@RequestMapping(value = "/hello.do")。value属性指明了它的映射路径,比如这里的映射路径为hello.do。此注解除了value属性外,还有如下属性:method、headers、params。
@RequestMapping(value= "/hello.do", method = RequestMethod.GET)此配置说明只有GET请求才能访问hello.do。
==================================================================
步骤六: 启动tomcat,发布项目,在地址栏输入 http://localhost:8080/springmvc10/index.jsp 进行测试,观察结果。