Spring Web MVC 入门秘籍:从概念到实践的快速通道(上)

Spring Web MVC 入门秘籍:从概念到实践的快速通道(上)

个人主页♡喜欢做梦

欢迎  👍点赞  ➕关注  ❤️收藏  💬评论


目录

一、什么是Spring Web MVC?

1.定义

2.关于MVC

2.1什么是MVC?

二、学习Sring MVC

1.项目准备

2.@RestController注解的介绍

3.@RequestMapping注解

1.@RequestMapping只用在类上(相当于“只给文件夹起名,不给文件起名”)

2.@RequestMapping只用在方法上(相当于“只给文件起名,不给文件夹起名”)

3.@RequestMapping用在类和方法上(相当于给文件夹和文件都取名)

三、Postman

1.什么是Postman?

2.关于API

3.传参介绍

1.普通传参:通过查询字符串来传参

2.form-data(完整表示为:multipart/form-data)

3.x-www-form-urlencoded

4.raw:可以上传任意格式的文本,比如:text、JavaScript、json、html、xml

4.传递参数

1.传递单个参数

2.传递多个参数

3.传递对象

4.传递数组

5.传递集合


一、什么是Spring Web MVC?

1.定义

Spring Web MVC是基于Servlet API构建的原始Web框架。是Spring框架中用于构建Web应用程序的模块,基于模型-视图-控制器(MVC)构架模式。简称Spring MVC。
  • Servlet:Servlet是Java企业级开发中的一项核心技术,主要用于在Web服务器上处理客户端请求并生成的动态响应。Servlet不能独立运行,把必须部署在支持Servlet规范放入容器内。

2.关于MVC

2.1什么是MVC?

定义

MVC是一种软件构架模式,广泛应用于图形用户界面(GUI)和Web应用程序的开发中国。他通过将应用程序的逻辑分为三个核心部分,实现了关注点分离,提高了代码的可维护性、可扩展性和复用性。

MVC的核心组成:模型(Model)、视图(View)、控制器(Controller),三者各司其职又相互协作。

步骤

模型(Model):负责管理应用程序的数据和业务逻辑。是应用程序的“数据中心”。例如学生的家庭、号码、住址等数据。视图(View):负责展示数据,是用户直接看到和交互的界面。例如我们平常经常看到的网页哪些界面。同一个模型可以对应多个视图。控制器(Controller):作为模型和视图之间的“桥梁”,负责协调两者的交互,处理用户的核心业务逻辑。例如,“订单控制器”,用户请求下单,调用商品,那么商品模型的减少库存,调用订单模型创建订单,最后跳转订单成功页面。
  • 用户通过视图发起交互(例如在网页点击跳转页面)。
  • 控制器接收用户请求。
  • 控制器调用模型,进行数据处理(如验证、存储)。
  • 模型处理完数据后,并将结果返回给控制器。
  • 控制器选择对应的视图,并传递模型数据给视图。
  • 视图展示模型数据,用户看到最终结果。

简要概括:用户->视图->控制器->模型->控制器->视图->用户

二、学习Sring MVC

1.建立连接:将用户(浏览器)和Java连接起来,访问一个地址可以调用Spring 程序

2.请求:用户请求一些参数,想办法获取这些参数。

3.响应:执行了业务逻辑,把程序执行结果返回给用户。

1.项目准备

创建项目

点击New Project创建新项目

点击Spring Initializr,没有的话需要自己去下载,随后点击下一步

出现下面的界面

  • 这里注意一下,只能包含小写字母、数字、连字符(-)、下划线、句号(.),不能包含大写字母。

点击启动项目

建立连接

我们创建一个类,实现用户与浏览器的交互

代码如下

@RestController public class hello { @RequestMapping("/sayhello") public String say(){ return "hello"; } }

在浏览器输入网址:127.0.0.1:8080/sayhello 查看结果

  • 127.0.0.1:本地主机地址,表示定位到当前电脑。
  • 8080:是Spring Boot应用的默认端口号。表示定位到“电脑上运行的Spring Boot程序”。
  • /sayhello:请求路径,接口地址。表示定位带请求支援的位置。
  • http://127.0.0.1:8080/sayhello: 表示的就是向本地计算机中的8080端口程序,获取资源位置。

2.@RestController注解的介绍

@RestController注解就像给控制器类贴一个特殊标签,告诉Spring框架:这个类里的方法是传给前端的返回数据。让控制器里的方法直接返回的东西当成响应内容发给前端,不用再走“找页面”流程。

如果不控制器加@RestController注解会访问页面会怎么样?

结果如下:

@RestController的核心作用是“让方法返回数据”

如果没有@RestController,通常会用普通的@Controller注解,或者干脆不加控制器注解,那么类就不会被识别为控制器。

  • 用@Controller,方法返回的是“页面地址”

  • 什么控制器注解都不加,那么类只是一个普通类,接口无法访问。

3.@RequestMapping注解

定义:@RequestMapping是Spring框架中一个非常重要的注解,用于将特定的Http请求方法映射带对应的处理方法。@RequestMapping(“/hello”)中里面的/hello表示调用路径里面的方法的代码。路径不加/也可以,没有影响,最好可以加一下。

@RequestMapping注解既可以用在类上,也可以用在方法上:

1.@RequestMapping只用在类上(相当于“只给文件夹起名,不给文件起名”)

@RestController @RequestMapping("/sayhello") public class hello { public String say(){ return "hello"; } }

相当于系统找到了文件夹,但不知道具体是哪个文件。就像你找一个住址,你只知道是哪个身份,但你并不知道是哪一个县哪一个乡,找不到具体是哪一个位置。

2.@RequestMapping只用在方法上(相当于“只给文件起名,不给文件夹起名”)

@RestController public class hello { @RequestMapping("/sayhello") public String say(){ return "hello"; } } 

相当于系统不知道是哪个文件夹的文件,但是会搜索所有文件夹来查找这个文件,直接通过文件名来定位。

那么如果出现相同的文件名呢?会怎么样,我们来试一下。

@RestController @RequestMapping("/sayhello") public class hello { public String say1(){ return "hello1"; } public String say2(){ return "hello2"; } }

系统只知道文件名,但是有两个相同的文件名,会出现路径重复的问题,发生报错现象。

3.@RequestMapping用在类和方法上(相当于给文件夹和文件都取名)

@RestController @RequestMapping("/sayhello") public class hello { @RequestMapping("/hello1") public String say1(){ return "hello1"; } @RequestMapping("/hello2") public String say2(){ return "hello2"; } }

相当于给文件夹和文件都取名,可以进行具体的定位,不容易发生报错。

查看RestMapping是否即支持Post和Get

@RestController @RequestMapping("/number") public class Rest { //即支持post,又支持get @RequestMapping("/1") public Integer num1(){ return 1; } }

另一种写法

 @RequestMapping(value = "6",method = {RequestMethod.GET,RequestMethod.POST}) public Integer num6(){ return 6; }
  • RestMapping即支持Post和Get

如果我只要只能用get或者Post其中一种呢?应该怎么写

只用get

 // 只支持get //写法1 @RequestMapping(value="/2",method = RequestMethod.GET) public Integer num2(){ return 2; } //写法2 @GetMapping("/3") public Integer num3(){ return 3; }

只请求Post

 //只请求Post //写法1 @RequestMapping(value="/4",method = RequestMethod.POST) public Integer num4(){ return 4; } //写法2 @PostMapping("/5") public Integer num5(){ return 5; }

三、Postman

1.什么是Postman?

Poatman是一筐广泛用于API开发、测试和调试的工具,被开发者、测试工具等广泛使用,其核心价值体现在高效、便捷的处理API相关工作。

Post是API开发调试的高效工具,核心优势:

  • 调试简单:图形化界面,填好参数就能发送请求,不用写代码,响应结果直观展示。
  • 功能全面:支持各种HTTP请求方法和数据格式。
  • 协作方便:可将API分组管理,共享给团队;多环境一键切换,不用重复配置。
  • 能自动化测试:可写脚本验证响应,批量运行测试并生成报告,还能集成开发流程中自动检测问题。
  • 实用小工具:保存请求历史、自动生成API文档等,提升效率。

2.关于API

API(Application Programming Interface,应用程序编程接口)是不同软件之间进行交互的一套规则、协议和工具的集合,他规定了一方如何向另一方请求服务或数据,以及另一方如何响应。API就像两个软件之间的“桥梁”或“服务员”,让他们能按照统一的方式沟通,而无需了解对方的内部工作原理。

就像我们去网购的时候,我们直接对自己想要的东西直接下单购买即可,不用了解其内部具体流程是怎么样执行的,最后他都会把你要的东西给到你。这里“下单的流程”就是API规则。

界面介绍

3.传参介绍

1.普通传参:通过查询字符串来传参

2.form-data(完整表示为:multipart/form-data)

表单提交数据,在form标签中加上enctyped=“multipart/form-data”,通常用于提交图片/文件。对应Content-type:multipart/form-data

3.x-www-form-urlencoded

form表单:对应Content-type:application/x-www-form-urlencoded

4.raw:可以上传任意格式的文本,比如:text、JavaScript、json、html、xml

4.传递参数

1.传递单个参数

import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/request") public class RequestController { @RequestMapping("/1") public String method(String string){ return "接收单个参数:"+string; } }
  • 接收时,参数名要一致,否则无法接收到参数
如果接受的参数基本类型不对应,会发生报错现象

基本类型和引用类型传参的区别

@RequestMapping("/2") public String method2(Integer i){ return "接收单个参数:"+i; } @RequestMapping("/3") public String method3(int j){ return "接收单个参数:"+j; }
  • 引用类型:传参时,若不传值,会赋值为null,不会发生报错现象
  • 基本类型:传参时,若不传值,不会发生报错现象

2.传递多个参数

 @RequestMapping("/4") public String method3(String name,Integer age){ return "接收多个参数: "+"姓名:"+name+" 年龄:"+age; }

3.传递对象

 @RequestMapping("/5") public String method3(User user){ return "接收对象参数:"+user.toString(); } @RestController @RequestMapping("/User") public class User { private String name; private int password; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getPassword() { return password; } public void setPassword(int password) { this.password = password; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User{" + "name='" + name + '\'' + ", password=" + password + ", age=" + age + '}'; } }

后端参数重命名:@RequestParam

如果前后端参数命名不一致,可能会出接收不到的情况,这时候我们可以使用@RequestParam来重命名前后端参数。

//将其重命名为str @RequestMapping("/6") public String method6(@RequestParam("str")String s){ return "接收参数:"+s; }
  • 使用@RequestParam重命名时参数就成了必传参数,否则将会报错
  • 使用@RequestParam时,就不能再使用原来的前后端的参数名

如果真的不想要传参数怎么办?
看一下@RequestParam的源码

其默认参数为true,所以一定要传参数,我们将其改为false就好了

@RequestMapping("/7") public String method7(@RequestParam(value = "str",required = false)String s){ return "接收参数:"+s; }

4.传递数组

@RequestMapping("/8") public String method8(String[] s){ return Arrays.toString(s); }

5.传递集合

传递集合需要使用@RequestParam用于接收单个请求参数。如果要接收List类型,需要显示开启“允许多值”模式,否则Spring无法解析

 @RequestMapping("/9") public List<Integer> method8(@RequestParam List<Integer> num){ return num; }

Read more

被问爆的Agent实战:从0到1搭建可落地AI智能体

被问爆的Agent实战:从0到1搭建可落地AI智能体

🎁个人主页:User_芊芊君子 🎉欢迎大家点赞👍评论📝收藏⭐文章 🔍系列专栏:AI 文章目录: * 【前言】 * 一、先搞懂:2026年爆火的AI Agent,到底是什么? * 1.1 Agent的核心定义 * 1.2 Agent的4大核心能力 * 1.3 2026年Agent的3个热门落地场景 * 二、框架选型:2026年6大主流Agent框架,新手该怎么选? * 三、实战环节:从0到1搭建可落地的“邮件处理Agent”(全程代码+步骤) * 3.1 实战准备:环境搭建(10分钟搞定) * 3.1.1 安装Python环境 * 3.1.2 创建虚拟环境(避免依赖冲突) * 3.

By Ne0inhk
2026年02月14日全球AI前沿动态

2026年02月14日全球AI前沿动态

一句话总结:2026年2月14日AI行业迎来多维度技术突破与产业落地,头部企业集中发布大模型新版本,具身智能、AI视频生成技术迭代加速,同时AI版权争议、伦理安全问题凸显,资本市场对AI领域投资热度持续高涨,行业向专业化、实时化、普惠化发展的同时也面临多重挑战。 一、模型与技术突破 1.1 通用大模型 字节跳动:发布豆包大模型2.0,历经21个月研发,含Pro、Lite、Mini三款通用Agent模型和Code版(Doubao-Seed-2.0-Code),Pro对标GPT 5.2和Gemini 3 Pro,Lite综合能力超豆包1.8,Mini面向低时延高并发场景;多模态理解能力达世界顶尖,视觉推理、空间推理表现突出,在SuperGPQA、HealthBench、IMO、CMO数学奥赛、ICPC编程竞赛中成绩优异,HLE-text获最高分,可处理复杂视觉输入、完成CAD设计/生物技术研究等专业任务,Code版接入TRAE,火山引擎提供API服务,标志字节在数据质量和训练效率上的重要突破,为企业提供高成本效益选择。 OpenAI:

By Ne0inhk
构建基于Go语言的高性能命令行AI对话客户端:从环境部署到核心实现

构建基于Go语言的高性能命令行AI对话客户端:从环境部署到核心实现

前言 在现代软件开发领域,Go语言凭借其卓越的并发处理能力、静态类型安全以及高效的编译速度,已成为构建命令行工具(CLI)的首选语言之一。本文将详细阐述如何在Ubuntu Linux环境下部署Go开发环境,并结合蓝耘(Lanyun)提供的DeepSeek大模型API,手写一个支持多轮对话、上下文记忆的智能终端聊天工具。 一、 基础运行环境的准备与构建 任何上层应用的稳健运行都离不开坚实的底层系统支持。本次部署的目标环境为Ubuntu LTS系列(20.04/22.04/24.04),这些长期支持版本保证了系统库的稳定性与安全性。硬件层面,建议配置至少1GB的内存与5GB的磁盘空间,以满足编译器运行及依赖包缓存的需求。 1. 系统包索引更新与系统升级 在进行任何开发工具安装之前,首要任务是确保操作系统的软件包索引与现有软件处于最新状态。这不仅能修复已知的安全漏洞,还能避免因依赖库版本过旧导致的编译错误。 执行系统更新操作: sudoapt update &&sudoapt upgrade -y 该指令分为两部分:apt update 用于从软件源服务器获取最新的软件包列

By Ne0inhk
人工智能:自然语言处理在客户服务领域的应用与实战

人工智能:自然语言处理在客户服务领域的应用与实战

人工智能:自然语言处理在客户服务领域的应用与实战 学习目标 💡 理解自然语言处理(NLP)在客户服务领域的应用场景和重要性 💡 掌握客户服务领域NLP应用的核心技术(如聊天机器人、意图识别、情感分析) 💡 学会使用前沿模型(如BERT、GPT-3)进行客户服务文本分析 💡 理解客户服务领域的特殊挑战(如实时性要求、多语言处理、用户体验) 💡 通过实战项目,开发一个客户服务聊天机器人应用 重点内容 * 客户服务领域NLP应用的主要场景 * 核心技术(聊天机器人、意图识别、情感分析) * 前沿模型(BERT、GPT-3)在客户服务领域的使用 * 客户服务领域的特殊挑战 * 实战项目:客户服务聊天机器人应用开发 一、客户服务领域NLP应用的主要场景 1.1 聊天机器人 1.1.1 聊天机器人的基本概念 聊天机器人是通过自然语言与用户进行交互的程序。在客户服务领域,聊天机器人的主要应用场景包括: * 客户服务:回答客户的问题(如“如何退货”、“商品价格”

By Ne0inhk