SpringMVC的架构有什么优势?——视图与模型(二)

前言

在这里插入图片描述
「作者主页」:雪碧有白泡泡
「个人网站」:雪碧的个人网站
「推荐专栏」

java一站式服务
React从入门到精通
前端炫酷代码分享
★ 从0到英雄,vue成神之路★
uniapp-从构建到提升
从0到英雄,vue成神之路
解决算法,一个专栏就够了
架构咱们从0说
★ 数据流通的精妙之道★
★后端进阶之路★

请添加图片描述

文章目录

  • 前言
  • 视图(View)
    • 1. 视图解析器(View Resolver):
    • 2. JSP视图(JSP View):
    • 3. Thymeleaf视图(Thymeleaf View):
    • 4. JSON视图(JSON View):
  • 模型(Model)
    • 1. 模型数据(Model Data):
    • 2. 加载模型数据(Load Model Data):
    • 3. 将模型数据传递给视图(Pass Model Data to View):

在这里插入图片描述

视图(View)

视图是展示结果的组件,它们负责渲染模型数据并生成HTML输出。Spring MVC支持多种视图技术,包括JSP、Thymeleaf等。
视图(View)是Spring MVC中渲染并呈现结果的组件,它们负责将模型数据渲染成HTML输出。Spring MVC支持多种视图技术,包括JSP、Freemarker、Velocity和Thymeleaf等。下面我们将深入探讨Spring MVC视图的核心概念和相应Java代码示例。

1. 视图解析器(View Resolver):

视图解析器负责将逻辑视图名称解析为实际的视图实现。在Spring MVC中,可以使用 InternalResourceViewResolver 作为默认的视图解析器,它将逻辑视图名称映射到JSP文件。

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/WEB-INF/views/"/><property name="suffix" value=".jsp"/>
</bean>

在上面的示例中,我们配置了一个InternalResourceViewResolver作为视图解析器,并将前缀设置为"/WEB-INF/views/“,后缀设置为”.jsp"。这意味着所有JSP文件都存储在"/WEB-INF/views/“目录下,并且必须以”.jsp"作为文件扩展名。

2. JSP视图(JSP View):

JSP视图是最常用的视图类型之一,它允许开发人员通过JSP标签来渲染模型数据并生成HTML输出。

@Controller
public class UserController {@RequestMapping(value = "/users/{id}", method = RequestMethod.GET)public ModelAndView getUser(@PathVariable("id") Long id) {User user = userService.getUserById(id);ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("user", user);modelAndView.setViewName("user");return modelAndView;}
}

在上面的示例中,getUser()方法使用ModelAndView对象来返回一个视图,并将一个用户对象添加到该视图的模型中。Spring MVC框架将自动使用 InternalResourceViewResolver 将"user"逻辑视图名称映射到"/WEB-INF/views/user.jsp" JSP文件。

3. Thymeleaf视图(Thymeleaf View):

Thymeleaf视图是一种流行的视图技术,它允许开发人员使用HTML标签来渲染模型数据并生成HTML输出。

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

在上面的示例中,我们向Maven配置文件添加了spring-boot-starter-thymeleaf依赖项,以引入Thymeleaf视图技术。

@Controller
public class UserController {@RequestMapping(value = "/users/{id}", method = RequestMethod.GET)public String getUser(@PathVariable("id") Long id, Model model) {User user = userService.getUserById(id);model.addAttribute("user", user);return "user";}
}

在上面的示例中,getUser()方法使用Spring的Model接口将一个用户对象添加到模型中,并返回一个"user"视图名称。Spring MVC框架将使用Thymeleaf视图解析器将"user"逻辑视图名称映射到"/templates/user.html" Thymeleaf模板文件。

4. JSON视图(JSON View):

JSON视图是一种轻量级的视图类型,它允许开发人员将数据渲染成JSON格式并发送给客户端。

@Controller
public class UserController {@RequestMapping(value = "/users/{id}", method = RequestMethod.GET, produces = "application/json")public ResponseEntity<User> getUser(@PathVariable("id") Long id) {User user = userService.getUserById(id);return new ResponseEntity<User>(user, HttpStatus.OK);}
}

在上面的示例中,getUser()方法使用 ResponseEntity 对象来返回一个用户对象,并将其设置为“application/json”格式。这意味着Spring MVC将自动将用户对象序列化为JSON字符串,并将其作为HTTP响应发送回客户端。

通过以上的介绍,我们了解了Spring MVC视图的核心概念和相应Java代码示例。总体而言,Spring MVC提供了丰富多样的视图技术,使开发人员能够根据需求选择最适合自己的视图类型。此外,Spring MVC还提供了强大的视图解析器机制,使开发人员能够轻松地进行视图名称和实际视图之间的映射。这些特性让Spring MVC成为一款流行的Web框架,深受众多开发人员和企业用户的喜爱。

需要注意的是,在使用Spring MVC视图时,开发人员应该重视数据安全性和性能问题。例如,在使用JSP视图时,开发人员应该避免在JSP页面中编写JavaScript代码,以防止跨站脚本攻击(XSS)。同时,开发人员还应该考虑缓存和压缩等机制,以优化视图的性能表现。

模型(Model)

模型代表了应用程序中的数据,是控制器和视图之间进行通信的桥梁。Spring MVC通过ModelAndView对象将模型数据传递给视图。
模型(Model)是Spring MVC框架中的一个核心概念,它代表了应用程序中的数据。模型对象可以被控制器使用,并且可以传递给视图进行展示。在Spring MVC中,我们通常使用ModelAndView对象来封装模型数据并将其传递给视图。

下面我们将深入探讨Spring MVC模型的核心概念和相应Java代码示例。

1. 模型数据(Model Data):

模型数据是指应用程序中需要在视图中呈现的数据。在Spring MVC中,我们通常使用Java Bean来表示模型数据,也就是所谓的模型对象。

public class User {private Long id;private String name;private Integer age;// Getter and Setter methods
}

在上面的示例中,我们定义了一个简单的User类作为模型对象,该类包含id、name和age三个属性。

2. 加载模型数据(Load Model Data):

加载模型数据是指从应用程序中获取模型数据的过程。在Spring MVC中,我们通常使用控制器来加载模型数据。

@Controller
public class UserController {@Autowiredprivate UserService userService;@RequestMapping(value = "/users/{id}", method = RequestMethod.GET)public ModelAndView getUser(@PathVariable("id") Long id) {User user = userService.getUserById(id);ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("user", user);modelAndView.setViewName("user");return modelAndView;}
}

在上面的示例中,getUser()方法使用 UserService 对象来获取指定id的用户对象,并将其添加到ModelAndView对象中。这样就完成了模型数据的加载过程。

3. 将模型数据传递给视图(Pass Model Data to View):

将模型数据传递给视图是指将封装了模型数据的ModelAndView对象传递给视图进行展示的过程。

@Controller
public class UserController {@Autowiredprivate UserService userService;@RequestMapping(value = "/users/{id}", method = RequestMethod.GET)public ModelAndView getUser(@PathVariable("id") Long id) {User user = userService.getUserById(id);ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("user", user);modelAndView.setViewName("user");return modelAndView;}
}

在上面的示例中,getUser()方法返回一个封装了模型数据的ModelAndView对象。其中,addObject()方法用于向模型中添加一个名为"user"的属性,该属性值是从数据库中查询得到的User对象。setViewName()方法设置了视图名称为"user",Spring MVC框架将根据视图名称自动查找并渲染对应的JSP文件。

通过以上的介绍,我们可以看出,模型(Model)是Spring MVC框架中非常重要的一个组件,它代表了应用程序中的数据,并且充当了控制器和视图之间的桥梁。只有深入理解模型的概念,并熟练掌握相应的Java代码技巧,才能够在实际开发中灵活运用Spring MVC框架,构建高效、可靠、易于维护的Web应用程序。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言每日一练(2)

前言&#xff1a; 每日一练系列&#xff0c;每一期都包含5道选择题&#xff0c;2道编程题&#xff0c;博主会尽可能详细地进行讲解&#xff0c;令初学者也能听的清晰。每日一练系列会持续更新&#xff0c;暑假时三天之内必有一更&#xff0c;到了开学之后&#xff0c;将看学业情…

leetcode 63. 不同路径 II

2023.8.9 这题是不同路径I的升级版&#xff0c;在路径上增加了障碍物&#xff0c;有障碍物的地方无法通过。 我的思路依然还是使用动态规划&#xff0c;dp[i][j]的含义依然是到&#xff08;i&#xff0c;j&#xff09;这个位置的路径个数。只需要在dp数组中将有障碍物的地方赋为…

js案例:1.简单计算器

目录 一.效果图 二.实现思路 整体思路 ​ 1.关键是dom操作 ​ 2.设置点击事件 3.数据类型的隐式转换和赋值 三.完整代码 一.效果图 二.实现思路 整体思路 1.关键是dom操作 通过 document.getElementById(id) 获取html中的dom元素 每一个html标签都是一个对象&…

CANoe通过Frame Histogram窗口统计报文周期(方便快捷)

文章目录 效果展示1.插入Frame Histogram窗口2.Activate3.运行CANoe&#xff0c;停止后查看write窗口 效果展示 统计报文周期信息输出在write窗口。 1.插入Frame Histogram窗口 2.Activate 3.运行CANoe&#xff0c;停止后查看write窗口 统计报文周期信息输出在write窗口。

Pytorch深度学习-----神经网络模型的保存与加载(VGG16模型)

系列文章目录 PyTorch深度学习——Anaconda和PyTorch安装 Pytorch深度学习-----数据模块Dataset类 Pytorch深度学习------TensorBoard的使用 Pytorch深度学习------Torchvision中Transforms的使用&#xff08;ToTensor&#xff0c;Normalize&#xff0c;Resize &#xff0c;Co…

数据结构刷题训练——链表篇(一)

目录 前言 题目一&#xff1a;链表的中间节点 思路 分析 题解 题目二&#xff1a;链表中倒数第k个结点 思路 分析 题解 题目三&#xff1a;合并两个有序链表 思路 分析 题解 方法二 题解 题目四&#xff1a;链表的回文结构 思路 分析 题解 总结 前言 今天我将开…

2023华数杯C题总结

前言 对这次比赛中遇到的问题和卡住的思路进行复盘&#xff0c;整理相关心得&#xff0c;供以后比赛参考 &#x1f9e1;1.认识数据类型&#x1f9e1; 连续变量&#xff1a;母亲年龄、妊娠时间、CBTS、EPDS、HADS、整晚睡醒时间、婴儿年龄 无序分类变量&#xff1a;婚姻状态、…

Gpt微信小程序搭建的前后端流程 - 前端小程序部分-2.确定交互所需的后端API(二)

Gpt微信小程序搭建的前后端流程 - 前端小程序部分-2.确定交互所需的后端API(二) 参考微信小程序-小柠AI智能聊天&#xff0c;可自行先体验。 根据上一节的小程序静态页面设计&#xff0c;需要从后端获取数据的主要4个点&#xff1a; 登录流程&#xff1b;获取今日已提问次数&a…

Unity制作护盾——2、力场冲击波护盾

Unity制作力场护盾 大家好&#xff0c;我是阿赵。   继续做护盾&#xff0c;这一期做一个力场冲击波护盾。 一、效果展示 主要的效果并不是这个球&#xff0c;而是护盾在被攻击的时候&#xff0c;会出现一个扩散的冲击波。比如上图在右边出现了冲击波 如果在左边被攻击&am…

MongoDB 6.0.8 安装配置

一、前言 MongoDB是一个基于分布式文件存储的数据库。由C语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。在高负载的情况下&#xff0c;添加更多的节点&#xff0c;可以保证服务器性能。 MongoDB 将数据存储为一个文档&#xff0c;数据结构由键值(key>value…

[分享]STM32G070 串口 乱码 解决方法

硬件 NUCLEO-G070RB 工具 cubemx 解决方法 7bit 改为 8bit printf 配置方法 添加头文件 #include <stdio.h> 添加重定向代码 #ifdef __GNUC__#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)#else#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)#endi…

卷积神经网络实现MNIST手写数字识别 - P1

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f366; 参考文章&#xff1a;365天深度学习训练营-第P1周&#xff1a;实现mnist手写数字识别&#x1f356; 原作者&#xff1a;K同学啊 | 接辅导、项目定制&#x1f680; 文章来源&#xff1a;K同…

SPM(Swift Package Manager)开发及常见事项

SPM怎么使用的不再赘述&#xff0c;其优点是Cocoapods这样的远古产物难以望其项背的&#xff0c;而且最重要的是可二进制化、对xcproj项目无侵入&#xff0c;除了网络之外简直就是为团队开发的项目库依赖最好的管理工具&#xff0c;是时候抛弃繁杂低下的cocoapods了。 一&…

C语言:打开调用堆栈

第一步&#xff1a;打断点 第二步&#xff1a;FnF5 第三步&#xff1a;按如图找到调用堆栈

使用Flask.Request的方法和属性,获取get和post请求参数(二)

1、Flask中的request 在Python发送Post、Get等请求时&#xff0c;我们使用到requests库。Flask中有一个request库&#xff0c;有其特有的一些方法和属性&#xff0c;注意跟requests不是同一个。 2、Post请求&#xff1a;request.get_data() 用于服务端获取客户端请求数据。注…

积累常见的有针对性的python面试题---python面试题001

1.考点列表的.remove方法的参数是传入的对应的元素的值,而不是下标 然后再看remove这里,注意这个是,删除写的那个值,比如这里写3,就是删除3, 而不是下标. remove不是下标删除,而是内容删除. 2.元组操作,元组不支持修改,某个下标的内容 可以问他如何修改元组的某个元素 3.…

【MMU】认识 MMU 及内存映射的流程

MMU&#xff08;Memory Manager Unit&#xff09;&#xff0c;是内存管理单元&#xff0c;负责将虚拟地址转换成物理地址。除此之外&#xff0c;MMU 实现了内存保护&#xff0c;进程无法直接访问物理内存&#xff0c;防止内存数据被随意篡改。 目录 一、内存管理体系结构 1、…

idea打开多个项目需要开多个窗口(恢复询问弹窗)

【版权所有&#xff0c;文章允许转载&#xff0c;但须以链接方式注明源地址&#xff0c;否则追究法律责任】【创作不易&#xff0c;点个赞就是对我最大的支持】 前言 仅作为学习笔记&#xff0c;供大家参考 总结的不错的话&#xff0c;记得点赞收藏关注哦&#xff01; 使用…

【TypeScript】中定义与使用 Class 类的解读理解

目录 类的概念类的继承 &#xff1a;类的存取器&#xff1a;类的静态方法与静态属性&#xff1a;类的修饰符&#xff1a;参数属性&#xff1a;抽象类&#xff1a;类的类型: 总结&#xff1a; 类的概念 类是用于创建对象的模板。他们用代码封装数据以处理该数据。JavaScript 中的…

一起学SF框架系列7.1-spring-AOP-基础知识

AOP(Aspect-oriented Programming-面向切面编程&#xff09;是一种编程模式&#xff0c;是对OOP(Object-oriented Programming-面向对象编程&#xff09;一种有益补充。在OOP中&#xff0c;万事万物都是独立的对象&#xff0c;对象相互耦合关系是基于业务进行的&#xff1b;但在…