企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
[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,会用就可以了。