用注解开发SpringMVC
Spring2.5以后,用注解开发SpringMVC的功能十分强大,注解也是SpringMVC的精髓。在实际开发中,都会使用注解来实现。
这让SpringMVC开发工作量最小化,开发者只要专注于业务逻辑及页面的编写实现。
1、web.xml文件
配置DispatcherServlet,及相应的servlet-mapping。
这个文件除了servlet-name,和springmvc的配置文件名,其余都是固定不变,可以复用的。
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="//xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="//www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="//xmlns.jcp.org/xml/ns/javaee //xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--注册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>
</web-app>
2、Spring bean配置文件
沿用官方命名规则,此处用springmvc-servlet.xml。这个文件除了要扫描的包路径,其余都是固定不变,可以直接复用的。
-
开启注解
- 新增context约束
- 开启自动扫描包
-
静态资源过滤
- 使用默认的default-servlet-handler
- 让Spring MVC不处理静态资源 .css .js .html .mp3 .mp4
-
支持mvc注解驱动
- 在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理。
而annotation-driven配置帮助我们自动完成上述两个实例的注入。
- 在spring中一般采用@RequestMapping注解来完成映射关系
-
视图解析器
- 默认使用InternalResourceViewResolver
- 配置.jsp文件全路径文件名的前缀、后缀。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="//www.springframework.org/schema/beans"
xmlns:xsi="//www.w3.org/2001/XMLSchema-instance"
xmlns:context="//www.springframework.org/schema/context"
xmlns:mvc="//www.springframework.org/schema/mvc"
xsi:schemaLocation="//www.springframework.org/schema/beans
//www.springframework.org/schema/beans/spring-beans.xsd
//www.springframework.org/schema/context
//www.springframework.org/schema/context/spring-context.xsd //www.springframework.org/schema/mvc //www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--自动扫描包,让指定包下的注解生效,由IOC容器统一管理-->
<context:component-scan base-package="controller"/>
<!--让Spring MVC不处理静态资源 .css .js .html .mp3 .mp4-->
<mvc:default-servlet-handler/>
<!--支持mvc注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理。
而annotation-driven配置帮助我们自动完成上述两个实例的注入。-->
<mvc:annotation-driven/>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>
</beans>
3、Controller类编写
使用注解开发SpringMVC,99%的工作量都在controller类编写。SpringMVC Annotation 使开发量最小化。
Controller负责解析用户请求,进行业务处理,并返回一个模型。
Controller通过实现接口和注解定义两种方法实现。
实现了Controller接口的类就是控制器,这是较老的方法。
一个控制器类只能有一个方法。多个方法要写多个controller。
推荐用注解定义实现。
-
@Controller
- 修饰类,保证该类能被Spring自动扫描到,自动装配为Spring bean
-
@RequestMapping
请求地址,将controller类或其特定方法映射到指定前端视图
- 修饰类,表示该类所有方法的响应路径以该地址作为父路径。
- 修饰方法:表示该方法响应路径,方法响应到指定前端视图。
-
return
-
返回值:视图jsp文件名
-
@Controller注解的类中,若方法返回值对应的jsp文件名存在,则会被视图解析器解析
-
@Controller //修饰类,保证该类能被Spring自动扫描到,自动装配为Spring bean
@RequestMapping("controller") //修饰类,表示该类所有方法的响应路径以该地址作为父路径
public class MyController {
//完整url://localhost:8080/(工程名)/controller/hello
@RequestMapping("/hello") //修饰方法:表示该方法响应路径,方法响应到指定前端视图。
public String sayHello(Model model){
model.addAttribute("msg", "Hello!SpringMVC Annotation!");
//返回值:视图jsp文件名
//@Controller注解的类中,若方法返回值对应的jsp文件名存在,则会被视图解析器解析
return "hello";
}
}
4、编写hello.jsp页面
放在/WEB-INF/jsp/路径下
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Zuka</title>
</head>
<body>
${msg}
</body>
</html>
5、测试
url://localhost:8080/springmvc_annotation_war_exploded/controller/hello