【Spring 篇】走进SpringMVC的世界:舞动Web的激情

2024-01-14 19:28

本文主要是介绍【Spring 篇】走进SpringMVC的世界:舞动Web的激情,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

嗨,亲爱的小白们!欢迎来到这篇关于SpringMVC的博客,让我们一起探索这个舞动Web的框架,感受它带来的激情和便利。在这个世界里,我们将学到SpringMVC的概述、开发步骤以及如何快速入门,一切都是如此的令人兴奋。

踏上舞台:SpringMVC概述

在我们深入了解SpringMVC之前,让我们先简单了解一下它是什么。SpringMVC是Spring框架的一个模块,用于构建Web应用程序。它采用了经典的MVC(Model-View-Controller)设计模式,将应用程序划分为三个主要的组件:

  • Model(模型):负责处理数据逻辑,与数据库交互,提供数据给View展示。
  • View(视图):负责用户界面的展示,将Model提供的数据呈现给用户。
  • Controller(控制器):负责处理用户请求,调用Model获取数据,并将数据传递给View展示。

SpringMVC通过这种分层的方式,使得我们能够更清晰地组织和管理代码,提高了应用程序的可维护性。

舞动的步伐:SpringMVC开发步骤

1. 项目初始化

首先,我们需要创建一个新的SpringMVC项目。可以使用Spring Initializr(https://start.spring.io/)来初始化一个基本的Spring Boot项目。选择你需要的配置,点击"Generate"下载项目压缩包,解压后导入到你喜欢的集成开发环境中。

2. 添加SpringMVC依赖

pom.xml文件中,添加SpringMVC的依赖:

<dependencies><!-- ...其他依赖 ... --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>
</dependencies>

这个依赖包含了构建基本的SpringMVC应用所需的一切。

3. 创建一个简单的Controller

src/main/java/com/example/demo目录下,创建一个名为DemoController.java的类,用于处理Web请求:

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;@Controller
public class DemoController {@GetMapping("/hello")public String hello(Model model) {model.addAttribute("message", "Hello, SpringMVC!");return "hello";}
}

这个简单的Controller定义了一个/hello的GET请求,返回一条简单的问候语。

4. 创建一个显示结果的View

src/main/resources/templates目录下,创建一个名为hello.html的HTML文件,用于展示Controller返回的数据:

<!DOCTYPE html>
<html>
<body><h2 th:text="${message}"></h2></body>
</html>

5. 启动应用

在项目的根目录下执行以下命令启动应用:

./mvnw spring-boot:run

或者在集成开发环境中直接运行DemoApplication.java中的main方法。

打开浏览器访问:http://localhost:8080/hello,你将看到页面上显示着"Hello, SpringMVC!"。

至此,我们已经成功完成了一个简单的SpringMVC应用的开发。接下来,让我们更深入地了解一下SpringMVC的一些核心概念。

感受激情:快速入门SpringMVC

1. 请求映射

在SpringMVC中,我们通过@RequestMapping注解来定义Controller处理的请求映射。例如,我们想要处理一个路径为/greet的GET请求,可以这样写:

@GetMapping("/greet")
public String greet() {return "greet";
}

这里,我们使用了@GetMapping注解,表示处理GET请求。返回值为字符串"greet",它将会被解析为视图名称,系统将会找到名为greet.html的模板文件。

2. 请求参数

在处理请求时,我们常常需要从URL中获取参数。SpringMVC提供了多种方式来接收请求参数,最简单的方式是直接将参数添加到方法的参数中:

@GetMapping("/greet")
public String greet(@RequestParam String name, Model model) {model.addAttribute("message", "Hello, " + name + "!");return "greet";
}

在这个例子中,我们通过@RequestParam注解将name参数绑定到方法的参数中。当我们访问/greet?name=John时,name参数将被设置为"John"。

3. 路径变量

有时候,我们希望从URL路径中提取参数。这时,我们可以使用路径变量(Path Variable)。例如,我们想要处理类似/greet/{name}的URL:

@GetMapping("/greet/{name}")
public String greetWithPathVariable(@PathVariable String name, Model model) {model.addAttribute("message", "Hello, " + name + "!");return "greet";
}

在这个例子中,我们使用@PathVariable注解将路径中的name提取出来,传递给方法参数。当我们访问/greet/John时,name参数将被设置为"John"。

4. 请求体

有时候,我们需要从请求体中获取数据。例如,处理POST请求时,我们可以通过@RequestBody注解将请求体的内容绑定到方法参数:

@PostMapping("/update")
public String update(@RequestBody User user) {// 处理User对象return "update-success";
}

在这个例子中,我们期望客户端发送一个JSON格式的User对象到/update路径。SpringMVC将自动将请求体中的JSON数据转换为User对象,传递给方法。

5. 视图解析器

SpringMVC使用视图解析器来将Controller返回的逻辑视图名称解析为实际的视图。默认情况下,Spring Boot使用Thymeleaf作为模板引擎,所以我们可以在src/main/resources/templates目录下创建相应的HTML文件,Spring Boot会自动识别并渲染。

6. 拦截器

拦截器允许我们在Controller处理请求前或者请求后执行一些额外的逻辑。我们可以创建一个拦截器类,实现HandlerInterceptor接口,并在配置中注册。

public class DemoInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {// 在请求到达Controller之前执行System.out.println("Pre Handle method is Calling");return true;}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {// 在请求处理之后但视图未渲染前执行System.out.println("Post Handle method is Calling");}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {// 在视图渲染之后执行System.out.println("Request and Response is completed");}
}

在配置类中注册拦截器:

@Configuration
public class WebConfig extends WebMvcConfigurerAdapter {@Beanpublic DemoInterceptor demoInterceptor() {return new DemoInterceptor();}@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(demoInterceptor());}
}

7. 异常处理

在SpringMVC中,我们可以通过@ExceptionHandler注解来处理Controller内部抛出的异常。在全局范围内,我们可以创建一个@ControllerAdvice注解的类,用于集中处理所有Controller的异常。

@ControllerAdvice
public class GlobalExceptionHandler {@ExceptionHandler(Exception.class)public String handleException(Exception e) {// 处理异常并返回错误页面return "error";}
}

8. 文件上传

处理文件上传是Web应用中常见的需求。SpringMVC提供了MultipartFile类来接收上传的文件,同时我们可以使用@RequestParam注解来绑定文件参数。

@PostMapping("/upload")
public String handleFileUpload(@RequestParam("file") MultipartFile file, Model model) {// 处理文件上传逻辑return "upload-success";
}

9. 表单验证

在SpringMVC中,我们可以使用@Valid@ModelAttribute注解来进行表单验证。定义一个简单的实体类,加上验证注解,如@NotNull@Size等,然后在Controller方法参数上使用@Valid注解。

@PostMapping("/register")
public String register(@Valid @ModelAttribute User user, BindingResult bindingResult) {if (bindingResult.hasErrors()) {// 处理验证失败的逻辑return "registration-form";}// 处理注册逻辑return "registration-success";
}

小结:舞动SpringMVC的激情

在这篇博客中,我们深入学习了SpringMVC的概述、开发步骤和快速入门。通过项目初始化、添加依赖、创建Controller和View,我们成功搭建了一个简单的SpringMVC应用。随后,我们学习了请求映射、请求参数的处理方式,以及如何使用路径变量、处理请求体等高级功能。

除此之外,我们还感受了拦截器的力量,学会了如何处理异常、实现文件上传和表单验证等实用功能。SpringMVC为我们提供了丰富而强大的功能,使得我们能够轻松构建高效、安全且易于维护的Web应用。

希望这篇博客能够激发你对SpringMVC的兴趣,让你在这个舞台上舞动的更加从容。如果你有任何问题或想要分享自己的经验,欢迎在评论区留下你的足迹。让我们一起沉浸在SpringMVC的激情世界,创造出更加出色的Web应用吧!💃🌐

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

这篇关于【Spring 篇】走进SpringMVC的世界:舞动Web的激情的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/606260

相关文章

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映