Java Web 7 请求响应(Postman)
前言(SpringBoot程序请求响应流程)
以上一章的程序为例,一个基于SpringBoot的方式开发一个web应用,浏览器发起请求 /hello 后 ,给浏览器返回字符串 “Hello World ~”。
而我们在开发web程序时呢,定义了一个控制器类Controller,请求会被部署在Tomcat中的Controller接收,然后Controller再给浏览器一个响应,响应一个字符在浏览器发起请求,请求了我们的后端web服务器(也就是内置串 “Hello World”。 而在请求响应的过程中是遵循HTTP协议的。
但是在Tomcat这类Web服务器中,是不识别我们自己定义的Controller的。而Tomcat是一个Servlet容器,支持Serlvet规范,因此在tomcat中是可以识别 Servlet程序的。
- Servlet(服务器小程序)是一种运行在 Web 服务器或应用服务器上的 Java 程序,用于处理客户端(如浏览器)发送的 HTTP 请求并生成响应。它是 Java Web 开发的核心组件之一,遵循 Java Servlet API 规范。
- 简单来说,当用户通过浏览器访问一个网站时,浏览器会发送 HTTP 请求到 Web 服务器,服务器中的 Servlet 程序就会接收并处理这些请求,比如获取用户请求的页面内容、处理用户提交的表单数据等,然后生成一个响应返回给浏览器,这个响应可以是 HTML 页面、XML 数据、JSON 数据或者其他类型的内容。

那么在SpringBoot进行web程序开发时,它其实内置了一个核心的Servlet程序 DispatcherServlet,称之为 核心控制器,也可以叫做 前端控制器。 DispatcherServlet 负责接收页面发送的请求,然后根据执行的规则,将请求再转发给后面的请求处理器Controller,请求处理器处理完请求之后,最终再由DispatcherServlet给浏览器响应数据。
那将来浏览器发送请求,会携带请求数据,包括:请求行、请求头;请求到达tomcat之后,tomcat会负责解析这些请求数据,然后呢将解析后的请求数据会传递给Servlet程序中的HttpServletRequest对象,那也就意味着 HttpServletRequest 对象就可以获取到请求数据。 而Tomcat,还给Servlet程序传递了一个参数 HttpServletResponse,通过这个对象,我们就可以给浏览器设置响应数据 。

一 请求

1、Postman(接口测试工具)
postman的安装使用教程 我已经在另一篇文章详细介绍 Postman安装使用教程-CSDN博客
2、简单参数
①、原始方式

Tomcat接收到http请求时:把请求的相关信息封装到HttpServletRequest对象中
在Controller中,我们要想获取Request对象,可以直接在方法的形参中声明 HttpServletRequest 对象。然后就可以通过该对象来获取请求信息:

②、SpringBoot方法
在Springboot方法中可以自动进行类型转换。在Springboot的环境中,对原始的API进行了封装,接收参数的形式更加简单。 对于简单参数来讲,只要保证请求参数名和Controller方法中的形参名保持一致,就可以获取到请求参数中的数据值。

发送Post请求:

如果形参与请求参数对应不上,也可以通过注解@RequestParam来进行映射:
但是如果没有设置@RequestParam注解,且方法形参名与请求参数名不一致,那么虽然会无法接收到请求数据,但是它不会报错

注解@RequestParam中的required属性默认为true,代表该请求参数必须传递,如果不传递就会报错:

③、小结

3、实体参数
在使用简单参数做为数据传递方式时,前端传递了多少个请求参数,后端controller方法中的形参就要书写多少个。如果请求参数比较多,通过上述的方式一个参数一个参数的接收,会比较繁琐。
①、简单实体对象
此时,我们可以考虑将请求参数封装到一个实体类对象中。 要想完成数据封装,需要遵守如下规则:请求参数名与实体类的属性名相同


User类 定义在实体类Pojo中

②、复杂实体对象

③、小结

如果是复杂实体对象,也只需按照对象层次结构关系即可接收嵌套实体类属性参数
4、数组集合参数
数组集合参数的使用场景:在HTML的表单中,有一个表单项是支持多选的(复选框),可以提交选择的多个值

多个值是怎么提交的呢?其实多个值也是一个一个逐个提交的
①、数组


②、集合



requestparam适用场景:
**`@RequestParam`注解的使用场景**
1- **绑定单个请求参数** - 当你需要从HTTP请求(通常是GET或POST请求)中获取单个参数时,可以使用`@RequestParam`。
例如,在一个处理用户登录的方法中,如果前端通过表单提交了用户的用户名和密码,后端方法可以使用`@RequestParam`来获取这些参数。
```java @RequestMapping("/login")
public String login(@RequestParam("username") String username, @RequestParam("password") String password) {
// 在这里进行登录验证逻辑
return "loginSuccess";
} ```
- 这里`@RequestParam("username")`和`@RequestParam("password")`分别用于获取名为“username”和“password”的请求参数,并将其绑定到对应的方法参数上。
2- **参数非必需情况** - `@RequestParam`还可以处理参数不是必需的情况。你可以通过设置`required`属性来指定参数是否必需。例如:
```java @RequestMapping("/search")
public String search(@RequestParam(name = "keyword", required = false) String keyword) {
if (keyword!= null) { // 进行搜索逻辑 }
return "searchResult";
} ```
- 在这个例子中,“keyword”参数不是必需的。如果前端没有传递“keyword”参数,`keyword`方法参数将为`null`。
3- **设置默认值** - 当参数不是必需且你希望在参数未传递时给方法参数赋予一个默认值时,可以使用`@RequestParam`的`defaultValue`属性。
例如: ```java
@RequestMapping("/page")
public String showPage(@RequestParam(name = "pageNum", defaultValue = "1") int pageNum) {
// 根据pageNum进行分页逻辑
return "pageContent"; }
```
- 这里如果前端没有传递“pageNum”参数,`pageNum`方法参数将默认为`1`。
4- **绑定复杂类型列表或数组** - 除了单个参数,`@RequestParam`还可以用于绑定列表或数组类型的参数。例如,当你希望从前端获取多个同名参数的值时(比如多选框的值): ```java
@RequestMapping("/select") public String selectOptions(@RequestParam("selectedOptions") List<String> selectedOptions) {
// 处理选中的选项
return "selectionResult";
} ```
- 前端可能通过`?selectedOptions=option1&selectedOptions=option2`这种形式传递参数,后端使用`@RequestParam`将这些同名参数值绑定到`List<String>`中。
一个细节点:

Array需要toString转换为字符串 而 List不需要 是因为:
1. **`String[]`数组的情况**
- 在Java中,`System.out.println()`方法没有对数组类型进行特殊的重载处理。当直接传递一个数组给`System.out.println()`时,它实际上是调用`Object`类的`toString()`方法。对于数组来说,`Object`类的`toString()`方法返回的是一个类似`[类型@哈希码]`的字符串,这并不是我们想要的数组内容的表示形式。
- 而`Arrays.toString()`方法是`java.util.Arrays`类提供的一个工具方法,它专门用于将数组转换为一个包含数组元素的字符串,格式为`[元素1, 元素2,...]`。所以当我们有一个`String[]`类型的参数时,需要使用`Arrays.toString()`来将数组内容以可读的形式输出。
2. **`List<String>`列表的情况** - 对于`List`类型,`java.util.List`继承自`java.util.Collection`,而`Collection`类已经重写了`toString()`方法。当调用`System.out.println()`输出一个`List`对象时,实际上调用的是`List`类重写后的`toString()`方法。
- 重写后的`toString()`方法会按照`[元素1, 元素2,...]`的格式返回列表中的元素。所以,当我们有一个`List<String>`类型的参数时,可以直接将其传递给`System.out.println()`,就能得到列表内容的可读形式输出。
5、日期参数
因为日期的格式多种多样(如:2022-12-12 10:05:45 、2022/12/12 10:05:45),那么对于日期类型的参数在进行封装的时候,需要通过@DateTimeFormat注解,以及其pattern属性来设置日期的格式

两个细节点:
1. **关于日期时间格式化模式中的大小写**
- 在`SimpleDateFormat`(用于格式化`java.util.Date`类型)以及相关的日期时间格式化模式中,`MM`和`HH`大写是有特定含义的,并且在`@DateTimeFormat`注解用于格式化`java.time.LocalDateTime`等类型时也遵循类似规则。
- `MM`用于表示月份,是月份的数字表示,范围是`01 - 12`。如果写成`mm`,则表示分钟,范围是`00 - 59`。
- `HH`用于表示24小时制的小时数,范围是`00 - 23`。如果写成`hh`,则表示12小时制的小时数,范围是`01 - 12`。
所以,为了准确表示你想要的日期时间格式部分,这些字母的大小写是很重要的。
2. **关于`LocalDateTime`输出中的`T`**
- `LocalDateTime`是Java 8引入的日期时间类型,它遵循ISO 8601日期时间格式标准。在ISO 8601格式中,日期和时间部分是通过`T`来分隔的。
- 例如,`2024 - 12 - 08T15:25:05`表示2024年12月8日15时25分05秒。`T`只是一个标准的分隔符,用于清晰地区分日期部分(`yyyy - MM - dd`)和时间部分(`HH:mm:ss`)。当你将`LocalDateTime`对象打印输出或者序列化为字符串时,就会按照这种标准格式来显示,方便在不同系统和应用之间进行日期时间信息的统一表示和交换。
6、JSON参数
在前后端进行交互时,如果是比较复杂的参数,前后端通过会使用JSON格式的数据进行传输。 (JSON是开发中最常用的前后端数据交互方式)
①、Postman在发送请求时,如何传递json格式的请求参数

②、在服务端的controller方法中,如何接收json格式的请求参数
服务端Controller方法接收JSON格式数据:
- 传递json格式的参数,在Controller中会使用实体类进行封装。
- 封装规则:JSON数据键名与形参对象属性名相同,定义POJO类型形参即可接收参数。需要使用 @RequestBody标识。
- @RequestBody注解:将JSON数据映射到形参的实体类对象中(JSON中的key和实体类中的属性名保持一致)


requestbody注解
1. **处理HTTP请求体中的数据时使用`@RequestBody`**
- **接收JSON数据**
- 在现代Web开发中,当客户端(如前端应用或者其他外部系统)通过POST、PUT等请求方法发送JSON数据给后端服务时,后端通常使用`@RequestBody`来接收和解析这些数据。例如,在一个基于Spring Boot的Web应用中,有一个用户注册的功能。前端会收集用户的姓名、年龄、邮箱等信息,并将这些信息组装成一个JSON对象,像这样:
```json { "name": "John Doe",
"age": 30,
"email": "johndoe@example.com" } ```
后端的Spring Boot控制器方法可以这样接收数据:
```java
@RequestMapping(value = "/register", method = RequestMethod.POST)
public String registerUser(@RequestBody User user) {
// 将用户信息保存到数据库等操作
return "success"; }
``` 这里假设`User`是一个Java类,包含`name`、`age`、`email`等属性。`@RequestBody`注解会自动将JSON数据解析并绑定到`User`对象的相应属性上。
- **接收XML数据(虽然现在JSON更常用)**
- 如果客户端发送XML格式的数据,也可以使用`@RequestBody`来处理。例如,假设客户端发送如下XML数据来表示一个订单:
```xml
<order>
<productId>
123
</productId>
<quantity>
5
</quantity>
<customerName>
Alice
</customerName>
</order> ```
后端可以定义一个`Order`类来匹配XML数据的结构,并且在控制器方法中使用`@RequestBody`来接收: ```java
@RequestMapping(value = "/placeOrder", method = RequestMethod.POST)
public String placeOrder(@RequestBody Order order) {
// 处理订单逻辑,如保存订单到数据库等
return "orderPlaced";
} ```
- **复杂数据类型传输**
- 当需要传输复杂的数据结构,如包含嵌套对象或者集合的对象时,`@RequestBody`非常有用。例如,一个包含多个商品信息的购物车对象,其中每个商品对象又包含商品名称、价格、数量等信息。前端将购物车数据以JSON格式发送: ```json
{
"cartId": "C001",
"items": [
{
"productName": "Book",
"price": 20.0,
"quantity": 2
},
{
"productName": "Pen",
"price": 3.0,
"quantity": 5
}
]
} ```
后端可以通过`@RequestBody`接收并解析这个复杂的购物车对象: ```java @RequestMapping(value = "/checkout", method = RequestMethod.POST)
public String checkout(@RequestBody ShoppingCart cart) {
// 计算总价、处理库存等结账逻辑
return "checkoutSuccess";
} ```
requestmapping注解:
@RequestMapping注解的基本概念和用途
@RequestMapping是 Spring MVC 中用于处理请求地址映射的注解。它可以用在类和方法级别上。
@RequestMapping注解的属性
value属性(或path属性,它们是等价的):用于指定请求路径。可以是一个简单的字符串路径,也可以是一个包含多个路径的数组method属性:用于指定请求方法。除了RequestMethod.GET和RequestMethod.POST外,还可以指定RequestMethod.PUT、RequestMethod.DELETE、RequestMethod.HEAD、RequestMethod.OPTIONS等。consumes属性:用于指定请求的MIME类型(媒体类型)。例如,consumes = "application/json"表示该方法只处理JSON格式的请求体。produces属性:用于指定响应的MIME类型。例如,produces = "application/json"表示该方法返回的响应是JSON格式。
7、路径参数
传统的开发中请求参数是放在请求体(POST请求)传递或跟在URL后面通过?key=value的形式传递(GET请求)
而在现在的开发中,还是经常会直接在请求的URL中传递参数。例如:
http://localhost:8080/user/1
http://localhost:880/user/1/0
上述的这种传递请求参数的形式,就称之为 路径参数
①、传递单个参数

②、传递多个参数
和传递单个参数方法相同,无非就是多写一个形参和注解,需要注意的是:形参要和传递的参数相同才能接收成功

8、相关代码
RequestController.java
package com.example.demo.controller;import com.example.demo.pojo.User;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.*;import java.time.LocalDateTime;
import java.util.Arrays;
import java.util.List;@RestController
public class RequestController {/*@RequestMapping("/simpleParam")public String simpleParam(String name, int age) {System.out.println(name + " " + age);return "OK";}*///1 简单参数@RequestMapping("/simpleParam")public String simpleParam(@RequestParam(name="name",required = false) String username, int age) {System.out.println(username + " " + age);return "OK";}//2 实体参数 简单实体参数 复杂实体参数@RequestMapping("/simplePojo")public String simplePojo(User user) {System.out.println(user);return "OK";}@RequestMapping("/complexPojo")public String complexPojo(User user) {System.out.println(user);return "OK";}//3 数组参数 集合参数@RequestMapping("/arrayParam")public String arrayParam(String[] hobby) {System.out.println(Arrays.toString(hobby));return "OK";}@RequestMapping("/listParam")public String listParam(@RequestParam List<String> hobby) {System.out.println(hobby);return "OK";}//4 日期参数@RequestMapping("/dateParam")public String dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime updateTime) {System.out.println(updateTime);return "OK";}//5 json参数@RequestMapping("/jsonParam")public String jsonParam(@RequestBody User user) {System.out.println(user);return "OK";}//6 路径参数@RequestMapping("/path/{id}")public String pathParam(@PathVariable Integer id) {System.out.println(id);return "OK";}@RequestMapping("/path/{id}/{name}")public String pathParam(@PathVariable Integer id, @PathVariable String name) {System.out.println(id + " " + name);return "OK";}
}
二、响应
1、@ResponseBody
在我们前面所编写的controller方法中,都已经设置了响应数据,那controller方法中的return的结果,怎么就可以响应给浏览器呢?

@RestController是两个注解的组合,@RestController = @Controller + @ResponseBody
2、统一响应结果
大家有没有发现一个问题,我们在前面所编写的这些Controller方法中,返回值各种各样,没有任何的规范

如果我们开发一个大型项目,项目中controller方法将成千上万,使用上述方式将造成整个项目难以维护。那在真实的项目开发中是什么样子的呢?
①、定义一个统一响应结构类 Result
在真实的项目开发中,无论是哪种方法,我们都会定义一个统一的返回结果。方案如下:

> 前端:只需要按照统一格式的返回结果进行解析(仅一种解析方案),就可以拿到数据

定义在一个实体类Result来包含以上信息,代码如下:
public class Result {
private Integer code;//响应码,1 代表成功; 0 代表失败
private String msg; //响应码 描述字符串
private Object data; //返回的数据
public Result() { }
public Result(Integer code, String msg, Object data) {
this.code = code;
this.msg = msg;
this.data = data;
}
public Integer getCode() {
return code;
}
public void setCode(Integer code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public Object getData() {
return data;
}
public void setData(Object data) {
this.data = data;
}
//增删改 成功响应(不需要给前端返回数据)
public static Result success(){
return new Result(1,"success",null);
}
//查询 成功响应(把查询结果做为返回数据响应给前端)
public static Result success(Object data){
return new Result(1,"success",data);
}
//失败响应
public static Result error(String msg){
return new Result(0,msg,null);
}
}
效果展示:

②、小结

相关文章:
Java Web 7 请求响应(Postman)
前言(SpringBoot程序请求响应流程) 以上一章的程序为例,一个基于SpringBoot的方式开发一个web应用,浏览器发起请求 /hello 后 ,给浏览器返回字符串 “Hello World ~”。 而我们在开发web程序时呢,定义了一…...
Android APP自学笔记
摘抄于大学期间记录在QQ空间的一篇自学笔记,当前清理空间,本来想直接删除掉的,但是感觉有些舍不得,因此先搬移过来。 Android导入已有外部数据库 2015.06.26在QQ空间记录:在Android中不能直接打开res aw目录中的数据…...
Linux 系统报打开的文件过多
1.问题 1804012290 [reactor-http-epoll-1] WARN i.n.channel.DefaultChannelPipeline - An exceptionCaught() event was fired, and it reached at the tail of the pipeline. It usually means the last handler in the pipeline did not handle the exception. - io.nett…...
javaWeb之过滤器(Filter)
目录 前言 过滤器概述 什么是过滤器 过滤器详细 过滤器的生命周期 过滤器的应用 创建一个简单的Filter类步骤 注意:指定拦截路径,我们有两种方式 实例 前言 本篇博客的核心 知道过滤器的整个拦截过程知道如何指定拦截路径知道过滤器的生命周期…...
ModStartBlog v10.0.0 发布时间自定义,多图快速粘贴,博客编辑器升级
ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用,支持后台一键快速安装,让开发者能快的实现业务功能开发。 系统完全开源,基于 Apache 2.0 开源协议。 功能特性 丰富的模块市场,后台一键快速安装 …...
Unexpected token ‘<‘, “<!doctype “... is not valid JSON
Unexpected token ‘<’, "<!doctype "… is not valid JSON 在前端开发时,遇到以下报错内容。 1.报错内容如下: // 报错内容 Uncaught (in promise) SyntaxError: Unexpected token <, "<!doctype "... is not valid…...
24/12/9 算法笔记<强化学习> PPO,DPPO
PPO是目前非常流行的增强学习算法,OpenAI把PPO作为目前baseline算法,首选PPO,可想而知,PPO可能不是最强的,但是是最广泛的。 PPO是基于AC架构,因为AC架构有一个好处,就是解决了连续动作空间的问…...
Linux下编译安装METIS
本文记录Linux下编译安装METIS的流程。 零、环境 操作系统Ubuntu 22.04.4 LTSVS Code1.92.1Git2.34.1GCC11.4.0CMake3.22.1 一、安装依赖 1.1 下载GKlib sudo apt-get install build-essential sudo apt-get install cmake 2.2 编译安装GKlib 下载GKlib代码, …...
【数据库】关系代数和SQL语句
一 对于教学数据库的三个基本表 学生S(S#,SNAME,AGE,SEX) 学习SC(S#,C#,GRADE) 课程(C#,CNAME,TEACHER) (1)试用关系代数表达式和SQL语句表示:检索WANG同学不学的课程号 select C# from C where C# not in(select C# from SCwhere S# in…...
amazon亚马逊滑动识别验证码
注意,本文只提供学习的思路,严禁违反法律以及破坏信息系统等行为,本文只提供思路 如有侵犯,请联系作者下架 本文识别已同步上线至OCR识别网站: http://yxlocr.nat300.top/ocr/other/15 亚马逊的滑动还原验证码数据集如下: 和某顶象的差不多,图片分割高度是中间固定的,…...
Android Studio 创建虚拟设备的详细图文操作教程
本篇文章主要讲解 Android Studio 创建模拟器详细图文操作,包含了每一步的详细操作,便于理解和掌握对模拟的创建。 日期:2024年12月9日 作者:任聪聪 运行效果: 说明:创建运行后,点击右侧如下图…...
网络安全法-附则
第七章 附 则 第七十六条 本法下列用语的含义: (一)网络,是指由计算机或者其他信息终端及相关设备组成的按照一定的规则和程序对信息进行收集、存储、传输、交换、处理的系统。 (二)网络安全ÿ…...
CSS核心(上)
CSS 介绍 层叠样式表(英语:Cascading Style Sheets, 缩写:CSS; 又叫串样式列表,级联样式表,串接样式表,阶层式样式表)是一种用来为结构化文档(HTML或XML应用)添加样式(…...
深度学习常用损失函数介绍
均方差损失(Mean Square Error,MSE) 均方误差损失又称为二次损失、L2损失,常用于回归预测任务中。均方误差函数通过计算预测值和实际值之间距离(即误差)的平方来衡量模型优劣。即预测值和真实值越接近&…...
HarmonyOS-中级(四)
文章目录 Native适配开发三方库的基本使用 🏡作者主页:点击! 🤖HarmonyOS专栏:点击! ⏰️创作时间:2024年12月09日11点12分 Native适配开发 Node-API HarmonyOS Node-API 是 HarmonyOS 提供的…...
React v19稳定版发布12.5
🤖 作者简介:水煮白菜王 ,一位资深前端劝退师 👻 👀 文章专栏: 前端专栏 ,记录一下平时在博客写作中,总结出的一些开发技巧✍。 感谢支持💕💕💕 目…...
【毕业设计选题】深度学习类毕业设计选题参考 开题指导
目录 前言 毕设选题 开题指导建议 更多精选选题 选题帮助 最后 前言 大家好,这里是海浪学长毕设专题! 大四是整个大学期间最忙碌的时光,一边要忙着准备考研、考公、考教资或者实习为毕业后面临的升学就业做准备,一边要为毕业设计耗费大量精力。学长给大家整…...
NanoLog起步笔记-4-Server端的两个线程
nonolog起步笔记-4-Server端的两个线程 Server端的两个线程两个线程的角色与各自的职责RuntimeLogger::compressionThreadMain线程 详细学习一下相关的代码第三个线程第一次出现原位置swip buffer Server端的两个线程 如前所述,nanolog的server端,相对而…...
linux zookeeper安装并服务化
1.版本信息 系统:centos7.6 java版本:java 8(已经安装好) zookeeper版本:3.6.3 2.zookeeper安装并测试 1.上传文件至指定目录并解压 切换至cd downloads 目录下, rz上传文件 解压:tar -zxvf apache-zookeeper-3.…...
很简单,但是很实用。把docker run改写成docker compose。
很简单,但是很实用。把docker run改写成docker compose。 在Docker的世界里,docker run命令是启动容器最直接的方式之一。然而,当项目复杂度增加,涉及多个服务时,管理这些容器和服务之间的依赖关系就会变得繁琐。这时,使用Docker Compose来定义和运行多容器Docker应用就…...
Python爬虫实战:研究MechanicalSoup库相关技术
一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...
web vue 项目 Docker化部署
Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段: 构建阶段(Build Stage):…...
ubuntu搭建nfs服务centos挂载访问
在Ubuntu上设置NFS服务器 在Ubuntu上,你可以使用apt包管理器来安装NFS服务器。打开终端并运行: sudo apt update sudo apt install nfs-kernel-server创建共享目录 创建一个目录用于共享,例如/shared: sudo mkdir /shared sud…...
《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》
引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...
srs linux
下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935,SRS管理页面端口是8080,可…...
成都鼎讯硬核科技!雷达目标与干扰模拟器,以卓越性能制胜电磁频谱战
在现代战争中,电磁频谱已成为继陆、海、空、天之后的 “第五维战场”,雷达作为电磁频谱领域的关键装备,其干扰与抗干扰能力的较量,直接影响着战争的胜负走向。由成都鼎讯科技匠心打造的雷达目标与干扰模拟器,凭借数字射…...
GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...
Python Ovito统计金刚石结构数量
大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...
Web后端基础(基础知识)
BS架构:Browser/Server,浏览器/服务器架构模式。客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端。 优点:维护方便缺点:体验一般 CS架构:Client/Server,客户端/服务器架构模式。需要单独…...
