SpringMVC的入门示例---基于注解的配置

时间:2023-03-09 03:49:35
SpringMVC的入门示例---基于注解的配置

  注解版的配置,主要的修改就是将原来使用<bean>创建的业务控制器对象,修改为是扫描标签扫描到容器.

  1、导入包

  SpringMVC的入门示例---基于注解的配置

  2、在 web.xml 配置核心控制器

 <?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>springmvc-demo-01-start</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<!-- 配置核心控制器 -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 指定配置文件的路径 默认情况下:配置文件的路径为:/WEB-INF/dispatcherServlet.xml -->
<init-param>
<!-- 注意:任何框架的参数名都可以在代码里面找到 -->
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>

  3、创建一个 Spring 的配置文件

 <?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/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
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-4.3.xsd"> <!-- 启动注解默认配置 -->
<!-- 如果不加这句话,就会将注解有的,而 xml 配置没有的功能失效 -->
<!-- 1. json 的自动转换 -->
<!-- 2. 上传组件不能用 -->
<!-- 3. mvc:开头的部分组件不用 -->
<mvc:annotation-driven></mvc:annotation-driven>
<!-- 扫描包以及其子包下的所有组件 -->
<context:component-scan base-package="cn.mgy"></context:component-scan> <!-- 2. 视图解释器,不用配置,默认已经配置了 jsp 视图解释器了 -->
</beans>

  4、创建一个业务控制器

 package cn.mgy.controller;

 import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; /**
* 业务控制层
* 必须要加上存储类型注解@Controller,<context:component-scan> 才可以将该类扫描到容器
* @author Administrator
*
*/
@Controller
public class UserController { /**
* 将映射路径配置在执行方法的上面
* @return
*/
// @RequestMapping(value="/say.do")
// public ModelAndView say(){
// ModelAndView modelAndView = new ModelAndView();
// // 设置返回视图
// modelAndView.setViewName("/hello.jsp");
// return modelAndView;
// } /**
* 将映射路径配置在执行方法的上面,返回也可以是一个字符串
* @return
*/
@RequestMapping(value="/say.do")
public String say(){
return "/hello.jsp";
} }

  5、创建一个请求的发送页面

 <%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<a href="${pageContext.request.contextPath }/say.do">say</a>
</body>
</html>

  6、创建一个返回的视图页面

 <%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h3>你好世界!!!!</h3>
</body>
</html>