一、导包
导包总是最重要的
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet.jsp/javax.servlet.jsp-api -->
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.3</version>
<scope>provided</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/jstl -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.10</version>
</dependency>
注意:1.Tomcat9 和Tomcat10要导的包不一样,10需要jakarta的包,9需要javax的包
2.Springmvc继承父工程的包可能创建失败,需要我们手动导入包
二、配置web.xml文件
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<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>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
配置指定的servlet位置,并且关联到springmvc-servlet.xml文件,并把启动等级设为1级,保证项目开始时就开始注册识别
注意:url中/与/*的区别
/可以识别所有地址,但是不能识别jsp文件
/*可以识别所有地址,而且也可以识别jsp文件
三、配置springmvc-servlet.xml文件
<?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
http://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:component-scan base-package="com.kuang.controller"/>
<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>
也是spring的配置文件,刚开始的三行分别代表
开启controller包下的所有类的注解生效
让SpringMVC不处理静态资源:例如html,css,mp3
第三行的前提是,如果想使用@RequestMapping注解生效的话,原本需要配置
-
DefaultAnnotationHandlerMapping
-
和一个AnnotationMethodHandlerAdapter实例
而配置了这个就可以在不注册两个类的前提下直接使用@RequestMapping注解
视图解析器的作用就是在下文方法返回的字符串中在前面和后面拼接地址,使得程序可以正确的找到对应的位置
四、编写实体类
@Controller
public class HelloController {
@RequestMapping("/h1")
public String Hello(Model model){
model.addAttribute("msg","hello");
return "hello1";
}
}
@Controller就已经注册了这个类
然后编写一个返回String类型的方法,返回值为要调用的jsp文件的名称,同时Model变脸的addAttribute方法可以让jsp页面中显示指定的数据
@RequestMapping中的值为启动客户端后访问的地址
五、编写jsp文件
首先声明jsp文件的名称一定要和controller类中返回的对象相同,否则会导致文件定位失效
就只返回一个${msg}文件就可以