注解开发SpringMVC

注解开发才是SpringMVC的精髓

第一步:新建一个Module,添加Web支持,建立包结构com.luo.controller

第二步:由于Maven可能存在资源过滤问题,我们再03的pom.xml中添加如下代码,完善配置

<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>

第三步:在pom.xml文件中引入相关依赖

    主要有Spring框架核心库,SpringMVC,servlet,JSTL等,我们在父依赖中已经引入

第四步:配置web.xml

    注意:1.web.xml版本问题,要最新版

        2.注册DispatcherServlet

        3.关联SpringMVC配置文件

        4.启动级别为 1

        5.映射路径为/(不要用/*)

<!--注册DispatcherServlet-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--关联一个springmvc的配置文件:[servlet-name]-servlet.xml-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<!--启动级别-->
<load-on-startup>1</load-on-startup>
</servlet>
<!--匹配所有的请求:(不包括.jsp) /-->
<!--匹配所有的请求:(包括.jsp) /*-->
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

第五步:添加Spring MVC配置文件

    让IOC的注解生效

    静态资源过滤:HTML,JS,CSS,图片,视频......

    MVC的注解驱动

    配置视图解析器

  在recource目录下添加spring-mvc.xml配置文件,配置的形式与Spring容器配置基本类似,为了支持基于注解的IOC,设置了自动扫描包的功能,具体配           置信息如下:

<?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:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">

<!--自动扫描包,让指定包下的注解生效,有IOC容器统一管理-->
<context:component-scan base-package="com.luo.controller"/>

<!--让Spring MVC不处理静态资源 .css .js .mp3 .html....-->
<mvc:default-servlet-handler/>

<!--
支持mvc注解驱动
在Spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理
而annotation-driven配置帮助我们自动完成上述两个实例的注入
-->
<mvc:annotation-driven/>

<!--视图解析器:DispatcherServlet给他的ModelAndView-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>

</beans>

第六步:创建Controller

  编写一个Java控制类:com.luo.controller.HelloController,注意编码规范

  @Controller是为了让Spring IOC容器初始化时自动的扫描到

  @RequestMapping是为了映射请求路径,这里因为类与方法上都有映射所以访问时应该是/HelloController/hello

  方法中生命Model类型的参数是为了把Action中的数据带到视图中

  方法返回的结果是视图的名称hello,加上配置文件中的前后缀变成WEB-INF/jsp/hello.jsp 

第七步:创建视图层

  在WEB-INF/jsp目录中创建hello.jsp,视图可以直接取出并展示从Controller带回的信息

   可以通过EL表示取出Model中存放的值,或者对象。

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>

${msg}
</body>
</html>

第八步:配置Tomcat,启动测试

小结:

1.新建一个web项目

2.导入相关jar包

3.编写web.xml,注册DispatcherServlet

4.编写springmvc配置文件

5.创建对应的控制类

6.完善前端视图和controller之间的对应

7.测试运行调试

 

SpringMVC配置三大件:

处理器映射器,处理器适配器,视图解析器

 

通常只需要手动配置视图解析器,处理器映射器和处理器适配器只需要开启注解驱动即可,而省去了大量的xml配置。

 

posted on 2022-05-06 17:28  键盘敲烂的朱  阅读(109)  评论(0编辑  收藏  举报