Spring MVC复习 —— 搭建Spring MVC项目
??摘要:这篇笔记是关于Spring MVC的复习,内容是如何搭建Spring MVC项目。
??让我们快速的搭建一个Spring MVC项目。
1.点击创建项目
data:image/s3,"s3://crabby-images/56591/565914d613e3bfd2c0fb32ef36be88cb8569ed84" alt="image-20220423162449674"
2.选择webapp模板并完成创建
??这里存在两个同名模板,我们选择下边这个:
data:image/s3,"s3://crabby-images/a7408/a74086901a6c6017d01704a3c9ce7129b796e2d8" alt="image-20220423162710353"
data:image/s3,"s3://crabby-images/a4fd8/a4fd80d89b9e043a3623d3cb4fa969064aabf653" alt="image-20220423162857169"
data:image/s3,"s3://crabby-images/e1dc0/e1dc097c2eeb3575403a23c1f45eb3b4713fb2ad" alt="image-20220423162918784"
data:image/s3,"s3://crabby-images/e3c3b/e3c3b71ace15949c0b2d3c9bd8bdaebd22cfa203" alt="image-20220423163009578"
3.导入依赖jar包
??昨天在导入依赖jar包的时候我遇到一个问题,就是在导入到一半的时候网断了,关于这种情况Maven没有像迅雷和百度网盘那样的下载断点机制,因而会出现严重的错误,关于这种问题我有一种解决办法,详情见链接:Maven项目中导入坐标依赖时报(Failure to transfer…)的错的问题 - 云杉木屋 - 博客园 (cnblogs.com)。
??接下来我们将下面的jar包依赖复制到我们的pom文件中:
<properties>
<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>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring4</artifactId>
<version>3.0.9.RELEASE</version>
</dependency>
</dependencies>
??如图所示:
data:image/s3,"s3://crabby-images/7ce87/7ce8702cdfceb26b061ab318793b92d104e24d1b" alt="image-20220423163449072"
4.修改XML文档
??我们将web.xml文档替换为下面的配置信息:
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
</web-app>
data:image/s3,"s3://crabby-images/46ac3/46ac38c0ef5973179502e23e7c3919ede51ddfaa" alt="image-20220423163632116"
??之后我们配置过滤器,前端控制器以及初始页面等信息,我们将下面的代码粘贴进web.xml文档中:
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<async-supported>true</async-supported>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.html</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>/index.html</welcome-file>
</welcome-file-list>
data:image/s3,"s3://crabby-images/c3e50/c3e5035f0c6c315b1bb67b1b05a13ca8808cbca5" alt="image-20220423163807931"
??现在这里有个报错的地方:springmvc.xml这是因为我们还没有创建这个配置文档,我们现在就配置它。
5.配置springmvc.xml
??关于这个配置文件我们其实可以给他起任意的名字,只要是在web.xml中引用时名字一样即可。现在我们在main目录下创建两个重要的目录:java 和resource 。
data:image/s3,"s3://crabby-images/cd69e/cd69ebf349528bf254adc7cfc2c647ddc843d644" alt="image-20220423164050717"
data:image/s3,"s3://crabby-images/33440/33440ce81578a3198213182e33e54b85ec7b0d66" alt="image-20220423164110301"
??然后我们在resource中创建一个配置文件,取名为springmvc.xml ,其实取什么都行,只要和web.xml中引用一致即可:
data:image/s3,"s3://crabby-images/b3faf/b3fafa645127b923528076af4ac0c0239ab74f6f" alt="image-20220423164144903"
data:image/s3,"s3://crabby-images/91c49/91c49816a957e35129edcce5f3de1a00c81d7191" alt="image-20220423164250198"
??之后我们将下面的配置信息粘贴到这个配置文件中去:
<?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
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<context:component-scan base-package="com.spruce"></context:component-scan>
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
<bean id="viewResolver" class="org.thymeleaf.spring4.view.ThymeleafViewResolver">
<property name="order" value="1"/>
<property name="characterEncoding" value="UTF-8"/>
<property name="templateEngine" ref="templateEngine"/>
</bean>
<bean id="templateEngine" class="org.thymeleaf.spring4.SpringTemplateEngine">
<property name="templateResolver" ref="templateResolver"/>
</bean>
<bean id="templateResolver" class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">
<property name="prefix" value="/html/" />
<property name="suffix" value=".html" />
<property name="templateMode" value="HTML5"/>
</bean>
<mvc:annotation-driven></mvc:annotation-driven>
</beans>
data:image/s3,"s3://crabby-images/8258a/8258a7e8f5aa8a82491fe38ca1badd1d3d0afa95" alt="image-20220423164636424"
??我们注意到这里有个报错的地方,这是因为在这个位置使用的是Spring的IOC控制权反转支持,这个配置标签是用来扫描我们要被代理生成对象的包的,我们现在没创建这个包,所有报错了,因为这块配置信息是别人写的模板我拿来用了,因此会出现这种先有蛋后有鸡的错误。不管怎样我们现在配置好springmvc.xml了,我们现在赶紧创建那个包。
6.创建被代理的包以及controller层
data:image/s3,"s3://crabby-images/382fa/382faa245c29caf2d6f1390d0d30616b4d83f8d5" alt="image-20220423165119879"
??叮叮叮叮!创建好了,就这么简单,我们现在可以观察到springmvc里边不报错了:
data:image/s3,"s3://crabby-images/1ad39/1ad39f878fffd8bfba3bd2f55f13fbffacf5b294" alt="image-20220423165206352"
??现在我们可以写一些简单的代码,并实现一些简单的逻辑了。我们做测试如下:
1.在controller包中创建名为HelloController的类
data:image/s3,"s3://crabby-images/95f05/95f050fa0f60eaad7e1efd7b5f0d871432a805c3" alt="image-20220423165413039"
2.往里边放上如下代码,完成后效果如上图:
package com.spruce.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloController {
@RequestMapping(path = "/hello.do")
public String sayHello(Model model){
System.out.println("入门方法执行了2...");
model.addAttribute("msg","hello,SpringMVC");
return "suc";
}
}
3.在webapp中创建index.html并粘贴上如下代码
<html>
<head>
<meta charset="utf-8">
<title>入门程序</title>
</head>
<body>
<h3>入门</h3><a href="/SpringMVCLearn/hello.do" >入门程序</a>
</body>
</html>
4.在webapp下创建html目录,在里边创建suc.html并粘贴代码如下:
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>成功</title>
</head>
<body>
<h1>Hello <b th:text="${msg}"></b></h1>
</body>
<script>
</script>
</html>
??然后就好了,我们用tomcat打开它,如何在idea中配置tomcat呢,方法如下:
1.点击add Configuration...
data:image/s3,"s3://crabby-images/9b7f0/9b7f0a20cd572177a677075ad2070d7da22b6f7b" alt="image-20220423165943874"
2.点击这个加号
data:image/s3,"s3://crabby-images/8c379/8c379e443513dfe8043b5b07f304a9d74f20ca7e" alt="image-20220423170011857"
3.选择tomcat的local,路径选择我们自己下载在电脑上的那个路径(如果我们配置了系统变量Tomcat会自动检测到)
data:image/s3,"s3://crabby-images/97da3/97da39a42b1385845edebb85fc4e905392801262" alt="image-20220423170043641"
data:image/s3,"s3://crabby-images/1aec0/1aec083a9d1bb55b199cbbbb1585418a969e6704" alt="image-20220423170200088"
4.点击Deployment
data:image/s3,"s3://crabby-images/bf0a5/bf0a522b80ce09ef740e2ac975694251e1afd900" alt="image-20220423170226547"
??点击这个加号选择Artifact :
data:image/s3,"s3://crabby-images/ea6c2/ea6c2eef6bcc5e913d455a000d34e963870ac9f7" alt="image-20220423170306476"
??选择下边这个:
data:image/s3,"s3://crabby-images/6eacf/6eacff81644afcb9cddc5fc1ff091ada9cfaa7ad" alt="image-20220423170350819"
??删掉这部分:
data:image/s3,"s3://crabby-images/274a9/274a9877252f45653ba596f2b9f938b157d062fe" alt="image-20220423170426770"
??然后apply就好了。
7.测试
??启动Tomcat后我们先会在浏览器中弹出这样一个页面:
data:image/s3,"s3://crabby-images/b0914/b091453d31f51e677de161c6c1ad7c19c0c20bb8" alt="image-20220423170639480"
??点击这个入门程序,我们跳转到如下页面:
data:image/s3,"s3://crabby-images/9d731/9d7317847ac8c055901e7d55c125cceac9856ea1" alt="image-20220423170706984"
??这就意味着成功了。
|