1.结构图
2.开始添加依赖pom.xml
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<!--版本锁定:为了解决版本统一改的问题-->
<spring.version>5.0.2.RELEASE</spring.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
<!--解决maven工程创建过慢的问题:create之后加入-->
</dependencies>
3.开始:配置servlet的控制器 web.xml
<!--01.前端控制器servlet-->
<servlet>
<!--04.给控制器器起个名dispatcherServlet-->
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--7.现在是还没有加载springmvc的配置文件,那么什么时候才加载,所以使用servlet来加载这个全局的初始化参数-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!--8.让本来是使用DispatcherServlet的时候才创建,现在是让项目使其加载的时候就马上创建-->
<load-on-startup>1</load-on-startup>
</servlet>
<!--02.映射:/表示在什么路径下都可以-->
<!--可以被请求到-->
<servlet-mapping>
<!--05.映射到这里来使用-->
<servlet-name>dispatcherServlet</servlet-name>
<!--03.你拦截的路径,发任何请求都会经过这个拦截到-->
<url-pattern>/</url-pattern>
</servlet-mapping>
4.编辑简单的控制器类controller
package cn.itcast.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/*1.控制器类*/
/*2.当点击index.jsp里面的文字来执行控制层的类——3*/
/*4.在springmvc.xml配置之后开启注解——5*/
@Controller
public class HelloController {
/*3.怎么执行一个类,那么先把类变成一个对象(面向对象的思想),才可以使用:那么现在就应该想到Spring中IOC思想:所以来到了刚刚配置的springmvc——4*/
/*5.把路径映射到index.jsp中——6*/
/*[email protected](path ="请求的路径")——7 配置springmvc可以使用*/
/*7.这样的话前端控制器就可以访问得到了*/
@RequestMapping(path = "/hello")
public String sayHello(){
System.out.println("hello SpringMVC");
return "success";
}
/*8.方法执行完之后,需要找到pages下的success.jsp并且解析,这样就得在springmvc中配一个视图解析器*/
}
5.首先:index.jsp配置
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>hello World</title>
</head>
<body>
<h2>入门程序</h2>
<%--hello:相对路径的一个写法--%>
<a href="hello">入门程序点击超链接进入一个java编写好的类</a>
</body>
</html>
6.在springmvc.xml配置之后开启注解(这里使用springIOC:给类创建一个对象来使用该类)
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--1.开启注解扫描-->
<context:component-scan base-package="cn.itcast"></context:component-scan>
<!--2.跳转页面的配置-->
<!--配置视图解析器来找到success.jsp并且解析该视图-->
<!--属性:id:解析器名 class:InternalResourceViewResolver解析器-->
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--文件目录下:前缀:prefix-->
<property name="prefix" value="/WEB-INF/pages/"></property>
<!--前缀:prefix:后缀为jsp的所有-->
<property name="suffix" value=".jsp"></property>
</bean>
<!--开启springMVC框架注解的支持-->
<mvc:annotation-driven/>
</beans>
7.配置success.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h2>入门成功啦!!!</h2>
</body>
</html>
总结:
1.加入所需依赖
2.首先开始编写控制器类controller,然后目的是实现点击前端的超链接——去调用该类执行该方法,然后跳转到成功界面。
3.基于该目的,我们开始配置web.xml中的servlet视图控制器(视图控制器+路径映射【拦截】)
<servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
4.然后在springmvc中加入配置注解的约束和扫描注解约束
5.最后在控制器类controller中加入注释(详情请往上)@Controller + @RequestMapping(path = "/hello")
6.然后在WEB-INFO加入pages视图成功的界面success.jsp
7.然后又在到springmvc中配置扫描success.jsp的路径,并且开启springMVC框架注解的支持
8.然后现在还没有找到springmvc的配置类,现在需要在servlet中配置启动扫描的springmvc路径
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
9.最后springmvc才能被使用