用註解開發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