Spring Web MVC 快速入门
创始人
2025-01-16 03:33:47
0

  • 🎥 个人主页:Dikz12
  • 🔥个人专栏:Spring学习之路
  • 📕格言:吾愚多不敏,而愿加学
  • 欢迎大家👍点赞✍评论⭐收藏

目录

什么是Spring MVC? 

MVC模式介绍 

​编辑学习Spring MVC

建立连接 

@RequestMapping 使⽤

​编辑实战练习 

加法计算器

用户登录 

接口定义


什么是Spring MVC? 

 官方描述:

来自:Spring Web MVC :: Spring Framework 

 翻译为中文:

Spring Web MVC是基于Servlet API构建的原始Web框架,从一开始就包含在Spring框架中。正式名称“Spring Web MVC”来自其源模块的名称( spring-webmvc ),但它更常被称“Spring MVC”。

MVC 是⼀种架构设计模式, 也⼀种思想, ⽽ Spring MVC 是对 MVC 思想的具体实现. 除此之外, Spring MVC还是⼀个Web框架. 所以,,Spring MVC 是⼀个实现了 MVC 模式的 Web 框架.

MVC模式介绍 

MVC 是 Model View Controller 的缩写,它是软件⼯程中的⼀种软件架构设计模式,它把软件系统分 为模型、视图和控制器三个基本部分.
  •  View(视图)指在应⽤程序中专⻔⽤来与浏览器进⾏交互,展⽰数据的资源.
  •  Model(模型)是应⽤程序的主体部分,⽤来处理程序中数据逻辑的部分.
  • Controller(控制器)可以理解为⼀个分发器,⽤来决定对于视图发来的请求,需要⽤哪⼀个模型来处理,以及处理完后需要跳回到哪⼀个视图。即⽤来连接视图和模型.

 不过Spring在实现MVC时,也结合⾃⾝项⽬的特点,做了⼀些改变,相对⽽⾔,下⾯这个图或许更加合适.(前后端分离)

学习Spring MVC

学习SpringMVC,重点也就是学习如何通过浏览器和⽤⼾程序进⾏交互.

主要分以下三个⽅⾯:

  1. 建⽴连接:将⽤⼾(浏览器)和Java程序连接起来,也就是访问⼀个地址能够调⽤到我们的Spring程序。
  2. 请求:  ⽤⼾请求的时候会带⼀些参数,在程序中要想办法获取到参数,所以请求这块主要是获取参数的功能.
  3. 响应:  执⾏了业务逻辑之后,要把程序执⾏的结果返回给⽤⼾,也就是响应.

⽐如⽤⼾去银⾏存款:

  1. 建⽴连接:去柜台
  2. 请求:带着银⾏卡,⾝份证去存款
  3. 响应:银⾏返回⼀张存折.

对于Spring MVC来说,掌握了以上3个功能就相当于掌握了Spring MVC.

建立连接 

在Spring MVC中使⽤ @RequestMapping 来实现 URL路由映射,也就是浏览器连接程序的作⽤.
 创建⼀个UserController类,实现⽤⼾通过浏览器和程序的交互,具体实现代码如下:

@RestController public class UserController {     @RequestMapping("/hello")     public String test() {         return "hello,spring mvc";     } }

 浏览器查看:127.0.0.1:8080/hello  ,就可以看到程序返回的数据了.

 

@RequestMapping 使⽤

@RequestMapping 是Spring Web MVC 应⽤程序中最常被⽤到的注解之⼀,它是⽤来注册接⼝的路由映射的.

@RequestMapping 即可修饰类,也可以修饰⽅法,当修饰类和⽅法时,访问的地址是类路径 + ⽅法路径.

@RestController @RequestMapping("/user") public class UserController {     @RequestMapping("/hello")     public String test() {         return "hello,spring mvc";     } }

访问地址: 127.0.0.1:8080/user/hello


实战练习 

加法计算器

需求:输⼊两个整数,点击"点击相加"按钮,显⽰计算结果.

前端代码准备: 

                 Document       

计算器

数字1:
数字2:

 接口定义:

请求路径:calc/sum
请求⽅式:GET / POST
接⼝描述:计算两个整数相加

响应内容:计算器计算结果:18

请求参数 :

参数名类型是否必须备注
num1Integer参与计算的第⼀个数
num2Integer参与计算的第⼆个数

实例:num1 = 12 && num2 = 6

 后端实现:

@RestController @RequestMapping("/calc") public class CalcController {     @RequestMapping("/sum")     public String calc(Integer num1,Integer num2) {         Integer sum = num1 + num2;         return "

计算机计算结果: "+sum+"

"; } }

用户登录 

 需求: ⽤⼾输⼊账号和密码,后端进⾏校验密码是否正确.

  1. 如果不正确,前端进⾏⽤⼾告知
  2.  如果正确,跳转到⾸⻚. ⾸⻚显⽰当前登录⽤⼾
  3. 后续再访问⾸⻚,可以获取到登录⽤⼾信息

接口定义

1.校验接口

 接口定义:

请求路径:/user/login
请求⽅式:POST
接⼝描述:校验账号密码是否正确

请求参数:

参数名类型是否必须备注
userNameString校验的账号
passwordString校验的密码

响应数据:

Content-Type: text/html
响应内容:

    true // 账号密码验证成功

    false  //账号或密码错误

2.查询登录用户接口

接口定义:

请求路径:/user/getLoginUser
请求⽅式:GET
接⼝描述:查询当前登录的⽤⼾

响应数据:

 Content-Type: text/html


响应内容:
     用户名   // zhangsan

前端实现:

1.登录界面.

   

用户登录

用户名:
密码:

2.登录成功界面.

     登录人:                 

后端实现:

@RestController @RequestMapping("/user") public class loginController {     @RequestMapping("/login")     public boolean login(String userName, String password, HttpSession session){         //账号密码为空 hasLength() 为null ,返回false         if (!StringUtils.hasLength(userName) || !StringUtils.hasLength(password)) {             return false;         }         //校验密码是否正确 (正常情况下是要走下数据库,这里就简单实现了)         if (!userName.equals("zhangsan") || !password.equals("123456")) {             return false;         }         System.out.println(password);         //密码验证成功,把用户存到session中】         session.setAttribute("userName",userName);         return true;     }      @RequestMapping("/getLoginUser")      public String getLoginUser(HttpSession session) {         //从session会话中直接拿         String userName = (String) session.getAttribute("userName");          if (StringUtils.hasLength(userName)) {             return userName;         }         return "";      } }

测试效果:

相关内容

热门资讯

红龙扑克辅助器!红龙扑克辅助器... 1、红龙扑克辅助器!红龙扑克辅助器(红龙扑克)好像存在有挂(详细辅助教程);详细教程。2、透视辅助简...
黑科技辅助挂!Wepoke一直... 黑科技辅助挂!Wepoke一直真的是有挂,Wepoke必胜都是真的有挂(详细计算辅助教程)1、ai机...
透视辅助!WpK透视辅助教程,... 透视辅助!WpK透视辅助教程,WPK透视本来是有挂(详细外卦挂教程)1、用户打开应用后不用登录就可以...
wepoke辅助机器人!wEP... wepoke辅助机器人!wEPOKE本来真的有挂,德州ai辅助神器wpk(详细透视辅助神器教程)1)...
德扑之星辅助器购买(德扑之星实... 德扑之星辅助器购买(德扑之星实战)辅助软件(辅助挂)一直是真的有挂(详细有作弊教程)1、起透看视 德...
黑科技透明挂!WEPoke辅助... 黑科技透明挂!WEPoke辅助工具,wepoke模拟器一贯有挂(详细ai代打教程)1、黑科技透明挂!...
透视辅助!红龙扑克辅助软件,红... 透视辅助!红龙扑克辅助软件,红龙扑克确实存在有挂(详细辅助教程)运辅助工具,进入游戏界面。进入辅助器...
wepoke有辅助挂!poke... wepoke有辅助挂!pokerworld真是存在有挂,wepower有外挂(详细ai代打辅助插件教...
aapoker透视辅助(aap... aapoker透视辅助(aapoker猫腻)aapoker 辅助工具(辅助挂)都是是有挂(详细辅助教...
透视辅助!AAPOKEr软件透... 透视辅助!AAPOKEr软件透明挂,aapoker有挂竟然是真的有挂(详细猫腻教程)1、aapoke...