[TOC]
# 注解方式
前面的例子,都是使用配置的方式进行跳转的配置,本例讲解如何使用注解的方式进行跳转的配置
## 步骤 1 : 先运行,看到效果,再学习
先将完整的项目(向老师要相关资料),配置运行起来,确认可用之后,再学习做了哪些步骤以达到这样的效果。
## 步骤 2 : 模仿和排错
在确保可运行项目能够正确无误地运行之后,再严格照着教程的步骤,对代码模仿一遍。
模仿过程难免代码有出入,导致无法得到期望的运行结果,此时此刻通过比较**正确答案** ( 可运行项目 ) 和自己的代码,来定位问题所在。
采用这种方式,**学习有效果,排错有效率**,可以较为明显地提升学习速度,跨过学习路上的各个槛。
## 步骤 3 : 效果
虽然效果和Hello Spring MVC中的一样,但是开发过程已经换成了**注解方式**
![](../images/Image016.png)
## 步骤 4 : 修改IndexController
在类前面加上@Controller 表示该类是一个控制器
在方法handleRequest 前面加上 @RequestMapping("/index") 表示路径/index会映射到该方法上
注意:不再让IndexController实现Controller接口
~~~
package com.dodoke.controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class IndexController{
@RequestMapping("/index")
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
ModelAndView mav = new ModelAndView("index");
mav.addObject("message", "Hello SpringMVC");
return mav;
}
}
~~~
## 步骤 5 : 修改springmvc-servlet.xml
去掉映射相关的配置,因为已经使用注解方式了
增加
`<context:component-scan base-package="com.dodoke.controller">`
表示从包controller下扫描有@Controller注解的类
最好直接复制这段配置代码
~~~
<?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"
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">
<!--
<bean id="simpleUrlHandlerMapping"
class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="/index">indexController</prop>
</props>
</property>
</bean>
<bean id="indexController" class="com.dodoke.controller.IndexController"></bean>
-->
<context:component-scan base-package="com.dodoke.controller"></context:component-scan>
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/page/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
~~~
## 步骤 6 : 测试
打开页面
`http://localhost:8080/springmvc/index`
看到的效果和通过配置是一样的
![](../images/Image016.png)
## 常见问题
1. 配置方式和注解方式有什么不同?
> 那么到底该用注解,还是xml文件配置方式呢? 他们各自有各自的优缺点:
> XML配置方式:
> 优:容易编辑,配置比较集中,方便修改,在大业务量的系统里面,通过xml配置会方便后人理解整个系统的架构,修改之后直接重启应用即可
> 缺:比较繁琐,配置形态丑陋, 配置文件过多的时候难以管理
> 注解方式:
> 优:方便,简洁,配置信息和 Java 代码放在一起,有助于增强程序的内聚性。
> 缺:分散到各个class文件中,所以不宜维护, 修改之后你需要重新打包,发布,重启应用。
> **个人体会**: 小项目,参与人数不多,不复杂的用注解,开发快速。 复杂项目,多人交互,配置量大,维护复杂度高的,用配置文件。
2. 可以xml和注解一起用吗?
> 可以,不过不建议,通常来说会统一做法,这样除了问题,大家对问题定位的位置有个预判。 如果两种方式同时用,在调试的时候,容易混淆。
3. 下列代码含义?
~~~
<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">
~~~
> 这是xml的命名空间和一些dtd,在这些空间里定义了标签context, 以及他的属性和子节点和相应的语法规范,你想要使用标签context需要引入相应的dtd. 类似于java类的imort 类。学习SpringMVC不需要深入了解xml,会用就可以了。