新建一个web项目,导入相关jar包
编写web.xml,注册DispatcherServlet
注意点:
- web.xml的版本,4.0
- 注册ispatcherServlet
- 关联springmvc的配置文件
- 启动级别为1(在服务器启动时最先被加载)
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!-- 注册DispatcherServlet,这是springMVC的核心:请求分发器,前端控制器-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 要绑定的spring文件-->
<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>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
编写spring-mvc配置文件
- 让ioc的注解生效
- 静态资源过滤:js,html,css,图片,视频…
- mvc的注解驱动
- 配置视图解析器
在resource目录下添加spring-servlet.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
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 开启注解支持-->
<context:annotation-config/>
<!--自动扫描包,该包下面的所有注解将生效-->
<context:component-scan base-package="com.tt.controller"/>
<!--
支持持mvc驱动
在Spring中一般采用@RequestMapping注解来完成映射关系
要想使该注解生效,必须在上下文中注册DefaultAnnotationHandlerMapping和一个
AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理
而<mvc:annotation-driven/>配置将自动帮我们完成上述两个实例的注入.
-->
<mvc:default-servlet-handler/>
<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>
在视图解析器中我们把所有的视图都存放在/WEB-INF/目录下,这样可以保证视图安全,因为这个目录下的文件,客户端不能直接访问。
创建对应包的名字:
创建一个简单jsp展示数据:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${msg}
</body>
</html>
创建相应的控制类,controller
编写一个java控制类,注意编码规范:
package com.tt.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloController {
//真实访问地址:项目名/helloController/hello
@RequestMapping("/hello")
public String hello(Model model){
// 在模型中添加属性msg与值,可以在jsp页面中取出并渲染。
model.addAttribute("msg","hello SpringMVC");
//web-inf/jsp/hello.jsp
return "hello";
}
}
@Controller
是为了让Spring IOC容器初始化时能自动扫描到;@RequestMapping
是为了请求映射路径;- 方法中声明
Model
类型的参数是为了吧Action中的数据带到视图中; - 方法返回的结果是视图的名字hello,加上配置文件的前后缀变成了
WEB-INF/jsp/hello.jsp
测试运行调试
配置tomcat,开启服务器,访问对应的请求路径.
OK,访问成功!