什么是MalformedStreamException,和WebKitFormBoundary有什么关系

org.apache.tomcat.util.http.fileupload.MultipartStream$MalformedStreamException

https://stackoverflow.org.cn/questions/53500627 

总结:

MalformedStreamException是因为没读取到上传文件请求体的末尾分隔符,上传文件使用的是multipart/form-data格式,对分隔符有要求


关联问题:

  • MalformedStreamException报错的原因
  • 什么是:multipart/form-data 的边界(boundary)
  • multipart/form-data 的内容格式一般是什么样子
  • 这个和WebKitFormBoundary 有关系吗,为什么有些分隔符是-----------------------------149742642616556


这个错误是什么?

org.apache.tomcat.util.http.fileupload.MultipartStream$MalformedStreamException 是 Tomcat 在处理文件上传时抛出的一个异常,意思是:
“你上传的文件数据格式不对,我(Tomcat)看不懂!”

为什么会出现?
  1. 上传的数据被截断了
    • 比如:文件还没传完,网络断了,或者用户取消了上传。
    • 类似:你正在给朋友发一篇长文,结果发到一半你手机没电了,朋友收到的是不完整的消息。
  2. 格式错误
    • HTTP 文件上传需要用特定的格式(multipart/form-data),就像快递包裹要有规范的包装。如果包装坏了(比如少了分隔符 boundary),Tomcat 就无法拆解。
    • 类似:你收到一个快递,但箱子没封好,里面的东西乱七八糟,你无法确定哪些属于哪个订单。
  3. 客户端(浏览器/APP)代码写错了
    • 比如:表单忘记写 enctype="multipart/form-data",或者用了错误的 API 上传文件。
  4. 服务器配置问题
    • Tomcat 对上传大小有限制(默认可能很小),如果文件太大,可能会被中途拦截。

如何解决?

1. 检查客户端代码(前端/APP)
    • 必须要有 enctype="multipart/form-data",否则文件无法正确打包发送。
  • 如果是 API 调用(比如用 Postman 或前端 JS):
    • 确保请求头是 Content-Type: multipart/form-data,并且数据格式正确。

确保表单正确(如果是网页上传):html

<form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="file"> <button type="submit">上传</button> </form> 
2. 检查服务器代码(Java 后端)

设置上传大小限制(避免大文件被拒绝):java

DiskFileItemFactory factory = new DiskFileItemFactory(); ServletFileUpload upload = new ServletFileUpload(factory); upload.setSizeMax(10 * 1024 * 1024); // 限制 10MB 

验证请求类型java

if (!ServletFileUpload.isMultipartContent(request)) { throw new ServletException("请用 multipart/form-data 格式上传文件!"); } 
3. 检查网络和中间件
  • 如果是通过代理(如 Nginx)、负载均衡或网关,确保它们没有提前终止请求(比如超时时间太短)。
  • 测试直接访问 Tomcat(绕过代理),看是否仍然报错。
4. 调试和日志
  • 打印原始请求(用工具如 Wireshark 或 tcpdump 抓包,或让前端输出请求数据)。

启用 Tomcat 的详细日志
在 log4j.properties 或 application.properties 中设置:properties

logging.level.org.apache.tomcat.util.http.fileupload=DEBUG 
5. 测试简单案例

用 Postman 或 curl 发送一个最小的文件上传请求,排除代码逻辑问题:bash

curl -X POST -F "file=@/path/to/small.txt" http://your-server/upload 

常见误区

  1. “我明明选了文件,为什么还报错?”
    • 可能是文件太大,或者前端没正确触发 multipart/form-data 格式。
  2. “本地测试没问题,上线后报错”
    • 检查生产环境的代理、防火墙或负载均衡是否截断了请求。
  3. “日志看不出问题”
    • 可能是客户端根本没发成功(用浏览器开发者工具或抓包工具确认请求是否完整)。

总结

这个错误的核心是 “Tomcat 收到的文件上传数据不符合规范”。解决方法就是:

  1. 确保客户端发了正确的数据(检查表单、API 调用)。
  2. 确保服务器能正确接收(检查代码、配置、日志)。
  3. 通过简单测试隔离问题(比如用 Postman 直连测试)。

如果还是搞不定,可以提供更多上下文(比如客户端代码、服务器配置、完整日志),我可以帮你进一步分析!


你提到的链接(https://stackoverflow.org.cn/questions/53500627)似乎是一个中文技术问答网站的帖子,但直接访问可能无法打开(可能是内部链接或已失效)。不过,根据问题标题 “org.apache.tomcat.util.http.fileupload.MultipartStream$MalformedStreamException 错误解决”,我可以结合之前的内容,用更通俗的中文详细解释这个错误及其解决方法。


一、这个错误是什么?

错误全称
org.apache.tomcat.util.http.fileupload.MultipartStream$MalformedStreamException
通俗解释
Tomcat 在处理文件上传时,发现你上传的数据“乱七八糟”,不符合规范,无法解析,于是直接报错拒绝。

类比生活场景
就像你收到一个快递包裹,但包装破损、没有标签,或者里面的东西被撕得粉碎,快递员会告诉你:“这个包裹有问题,我无法投递。”


二、为什么会出现这个错误?

1. 文件没传完(最常见)
  • 原因:上传过程中网络断了、用户取消了上传、服务器超时等。
  • 表现:文件只传了一部分,Tomcat 收到的是“半成品”。
  • 类比:你正在用手机看视频,突然没信号了,视频卡在中间无法播放。
2. 上传格式错误
  • 原因:HTTP 请求的 Content-Type 不是 multipart/form-data,或者缺少分隔符 boundary
  • 表现:Tomcat 不知道如何拆解你上传的数据。
  • 类比


这个网页(https://stackoverflow.org.cn/questions/53500627)讨论的是一个 Java 文件上传时抛出的 MultipartStream$MalformedStreamException 错误,具体是使用 org.apache.commons.fileupload 库解析 multipart/form-data 数据时出现的格式问题。以下是核心内容总结:


问题背景

用户尝试解析一个 multipart/form-data 格式的 HTTP 请求体(包含文件上传),但代码抛出异常:

java

org.apache.commons.fileupload.MultipartStream$MalformedStreamException: Stream ended unexpectedly 

关键代码片段

java

String byteString = "-----------------------------149742642616556\r\n" + "Content-Disposition: form-data; name=\"file\"; filename=\"test.txt\"\r\n" + "Content-Type: text/plain\r\n\r\n" + "test\r\n" + // 注意这里的换行符 "-----------------------------149742642616556--\r\n"; Pattern pattern = Pattern.compile("(?m)\\A-+\\d+$"); // 正则匹配 boundary Matcher matcher = pattern.matcher(byteString); String boundary = null; while (matcher.find()) { boundary = matcher.group(); } // 使用 boundary 解析数据时抛出异常 

错误原因分析

1. 换行符(CRLF vs LF)问题
  • RFC 2046 规范multipart/form-data 的边界(boundary)前后必须使用 CRLF(\r\n 作为换行符。
  • 用户代码中的问题
    • 数据末尾的 test\r\n-----------------------------... 中,test 后仅用了 \n(LF),而非规范的 \r\n(CRLF)。
    • 这导致 MultipartStream 无法正确识别边界,抛出 MalformedStreamException
2. 正则表达式匹配边界错误
  • 用户原始正则 (?m)\\A-+\\d+$ 会匹配到 --- 和数字,但 包含了多余的短横线--),而实际 boundary 参数值不应包含前导 --
  • 修正后的正则:(?m)\\A--(-*\\d+)$,通过捕获组提取纯 boundary 值。

解决方案

1. 修复换行符

确保所有换行符为 CRLF(\r\n

java

String byteString = "-----------------------------149742642616556\r\n" + "Content-Disposition: form-data; name=\"file\"; filename=\"test.txt\"\r\n" + "Content-Type: text/plain\r\n\r\n" + // 确保这里是 \r\n "test\r\n" + // 修复为 \r\n "-----------------------------149742642616556--\r\n"; 
2. 修正正则表达式

提取纯 boundary 值(不包含前导 --):

java

String regexp = "(?m)\\A--(-*\\d+)$"; //匹配 --xxx,提取 xxx Pattern pattern = Pattern.compile(regexp); Matcher matcher = pattern.matcher(byteString); String boundary = null; while (matcher.find()) { boundary = matcher.group(1); // 获取捕获组内容(xxx) } 
3. 添加初始换行符(可选)

如果数据开头缺少换行符,可能导致解析失败,可手动添加:

java

byteString = "\r\n" + byteString; // 在数据开头添加 CRLF 

验证代码

用户提供了一个可运行的 最小复现代码(MCVE),用于测试修复后的逻辑:

java

import java.util.regex.*; import java.io.*; import org.apache.commons.fileupload.*; public class Test { public static void main(String[] argv) { String byteString = "-----------------------------149742642616556\r\n" + "Content-Disposition: form-data; name=\"file\"; filename=\"test.txt\"\r\n" + "Content-Type: text/plain\r\n\r\n" + "test\r\n" + "-----------------------------149742642616556--\r\n"; String regexp = "(?m)\\A--(-*\\d+)$"; Pattern pattern = Pattern.compile(regexp); Matcher matcher = pattern.matcher(byteString); String boundary = null; String contentType = null; while (matcher.find()) { boundary = matcher.group(1); contentType = "multipart/form-data; boundary=\"" + boundary + "\""; } MultipartStream multipartStream = new MultipartStream( new ByteArrayInputStream(byteString.getBytes()), boundary.getBytes() ); ByteArrayOutputStream bos = new ByteArrayOutputStream(); try { multipartStream.readBodyData(bos); // 读取数据 } catch (Exception e) { e.printStackTrace(); } byte[] byteBody = bos.toByteArray(); System.out.println("解析结果: " + new String(byteBody)); } } 

输出结果

boundary = "---------------------------149742642616556" 解析结果: test 

总结

  1. 问题根源:换行符不符合 RFC 规范(缺少 \r)和正则表达式匹配错误。
  2. 修复方法
    • 统一使用 \r\n 作为换行符。
    • 修正正则表达式,提取纯 boundary 值。
    • 可选:在数据开头添加 \r\n
  3. 验证工具:通过最小复现代码确认修复效果。

如果遇到类似问题,可以按照上述步骤检查数据格式和解析逻辑。


在HTTP协议中,multipart/form-data的边界(boundary) 是用于分隔表单中多个不同部分(如文本字段、文件上传等)的特殊字符串。它的核心作用是确保接收方能准确识别每个部分的起始和结束位置,尤其在混合传输文本和二进制数据(如文件)时至关重要。


1. 边界的作用

  • 分隔多部分数据:当表单包含文件上传或多个字段时,数据会被编码为多个部分,每个部分用边界字符串标记。
  • 防止数据混淆:边界确保接收方(如服务器)能区分不同字段的值,即使某些字段内容本身包含与边界相似的字符串。

2. 边界的规范(RFC 2046)

  • 格式要求
    • 边界必须以 两个短横线 -- 开头,后跟一个唯一字符串(如随机生成的数字或字母)。
    • 边界的结束需用 CRLF\r\n 终止。
    • 示例:--149742642616556\r\n
    • 这里的 boundary=----WebKitFormBoundaryABC123 声明了后续数据中使用的边界字符串。

Content-Type 头中的声明http

Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryABC123 

3. 边界在请求体中的使用

示例:上传文件 test.txt 的请求体片段:

--149742642616556\r\n Content-Disposition: form-data; name="file"; filename="test.txt"\r\n Content-Type: text/plain\r\n\r\n test\r\n --149742642616556--\r\n # 最后的边界以 -- 结尾表示结束 

每个部分的格式

--<boundary>\r\n Content-Disposition: form-data; name="字段名"; filename="文件.txt"\r\n Content-Type: 文本/二进制类型\r\n\r\n 实际数据\r\n 

4. 关键注意事项

  • 唯一性:边界字符串必须足够随机,避免与数据内容重复。例如,浏览器通常生成类似 ----WebKitFormBoundaryABC123 的字符串。
  • 换行符(CRLF)
    • 边界前后必须使用 \r\n(回车+换行),而非仅 \n
    • 若换行符错误,服务器可能无法正确解析,抛出 MalformedStreamException 等异常。
  • 结束标记:最后一个边界需以 -- 结尾(如 --149742642616556--),表示数据结束。

5. 常见问题

    • 后果:服务器无法识别边界,解析失败。
  • 修复方法
    • 确保边界前后有 \r\n
    • 使用正则表达式提取纯 boundary 值(不含前导 --)。

错误示例java

// 错误:边界前缺少 \r\n,且末尾换行符为 \n 而非 \r\n String byteString = "test\n--149742642616556--\n"; 

总结

  • 边界是 multipart/form-data 请求中的分隔符,格式为 --<唯一字符串>\r\n
  • 规范要求:必须声明在 Content-Type 头中,且严格遵循换行符(CRLF)规则。
  • 实际应用:文件上传、混合表单数据传输时,边界确保数据被正确解析。

理解边界的规范和常见陷阱,能有效避免文件上传时的解析错误。


multipart/form-data 是 HTTP 协议中用于上传文件或提交包含多种数据类型(如文本、文件等)的表单时使用的编码方式。它的核心是通过边界(boundary)将不同部分的数据分隔开,确保接收方能正确解析每个字段的值。以下是其内容格式的详细说明和示例:


1. 整体结构

multipart/form-data 请求的内容由多个部分(part)组成,每个部分代表一个表单字段(如文本输入框、文件上传等)。所有部分通过边界字符串分隔,最后以一个结束边界标记请求结束。

基本格式
--<boundary>\r\n Content-Disposition: form-data; name="字段名"[; filename="文件.txt"]\r\n [Content-Type: 文件类型]\r\n\r\n 字段值或文件内容\r\n --<boundary>\r\n [其他部分...] --<boundary>--\r\n # 结束标记 

2. 关键组成部分

(1) 边界(Boundary)
  • 作用:分隔不同部分的数据。
  • 格式
    • 以 -- 开头,后跟一个唯一字符串(如随机生成的数字或字母)。
    • 示例:--149742642616556

声明:在 Content-Type 头中指定,例如:http

Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryABC123 
(2) 每个部分的头部
  • Content-Disposition:必填,描述字段名称和类型(普通字段或文件)。
  • Content-Type:可选,指定文件内容的 MIME 类型(如 text/plainimage/jpeg)。若未指定,默认是 application/octet-stream(二进制流)。

文件上传字段

Content-Disposition: form-data; name="file"; filename="test.txt" 

普通文本字段

Content-Disposition: form-data; name="username" 
(3) 字段值或文件内容
  • 文本字段:直接是字符串值。
  • 文件字段:文件的二进制数据。
(4) 结束标记
  • 最后一个边界后需以 -- 结尾,表示请求结束。
    • 示例:--149742642616556--

3. 完整示例

示例 1:普通表单(文本字段)

http

POST /upload HTTP/1.1 Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryABC123 ----WebKitFormBoundaryABC123\r\n Content-Disposition: form-data; name="username"\r\n\r\n JohnDoe\r\n ----WebKitFormBoundaryABC123\r\n Content-Disposition: form-data; name="password"\r\n\r\n 123456\r\n ----WebKitFormBoundaryABC123--\r\n 
示例 2:文件上传

http

POST /upload HTTP/1.1 Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryXYZ789 ----WebKitFormBoundaryXYZ789\r\n Content-Disposition: form-data; name="file"; filename="test.txt"\r\n Content-Type: text/plain\r\n\r\n This is the content of the file.\r\n ----WebKitFormBoundaryXYZ789\r\n Content-Disposition: form-data; name="description"\r\n\r\n A sample text file.\r\n ----WebKitFormBoundaryXYZ789--\r\n 

4. 关键注意事项

  1. 换行符(CRLF)
    • 每个部分之间必须用 \r\n(回车+换行)分隔。
  2. 边界唯一性
    • 边界字符串需足够随机,避免与数据内容重复。浏览器通常自动生成(如 ----WebKitFormBoundaryABC123)。
  3. 文件类型声明
    • 上传文件时,建议明确指定 Content-Type(如 image/jpeg),否则可能被默认视为二进制流。
  4. 结束标记
    • 最后一个边界必须以 -- 结尾(如 --boundary--),否则服务器可能认为数据未传输完成。

边界前后也需有 \r\n,例如:

--boundary\r\n [头部...]\r\n\r\n [内容]\r\n 

5. 常见问题

    • 后果:服务器可能抛出 MalformedStreamException
  • 修复方法
    • 确保所有换行符为 \r\n
    • 检查边界字符串是否与 Content-Type 头中声明的一致。

错误示例http

--boundary\n Content-Disposition: form-data; name="file"\n [内容] --boundary-- # 缺少 \r\n,可能导致解析失败 

总结

  • multipart/form-data 用于混合传输文本和文件数据,通过边界分隔不同部分。
  • 每个部分包含头部(Content-DispositionContent-Type)和内容。
  • 关键规则
    • 边界以 -- 开头,结束时加 --
    • 使用 \r\n 换行。
    • 文件字段需声明 filename 和 Content-Type

理解这些规则能避免文件上传时的解析错误,确保数据正确传输。

WebKitFormBoundary 和类似 -----------------------------149742642616556 的分隔符(boundary)本质上是同一概念的不同表现形式,它们的核心作用都是作为 multipart/form-data 请求中分隔数据部分的标记。两者的区别主要在于生成方式和命名习惯,具体关系及原因如下:


1. WebKitFormBoundary 的来源

  • 浏览器自动生成
    当使用浏览器(如 Chrome、Safari)的表单提交或 FormData 对象上传文件时,浏览器会按照规范自动生成一个唯一的 boundary 字符串,并通常以 WebKitFormBoundary 为前缀(例如 ----WebKitFormBoundaryABC123)。
    • 命名习惯
      WebKit 是浏览器引擎的名称(Chrome/Safari 使用 WebKit 或 Blink 引擎),FormBoundary 表示这是表单的边界字符串。这种命名方式是浏览器开发者的约定,便于调试时识别。

示例
浏览器生成的请求头可能如下:http

Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryABC123 

2. 纯数字分隔符(如 -----------------------------149742642616556)的来源

  • 手动生成或工具生成
    当开发者手动构造 multipart/form-data 请求(如使用 Postman、cURL 或后端代码)时,boundary 可以是任意符合规范的字符串,通常选择随机数字或字母组合(如 149742642616556)。
    • 规范要求
      boundary 只需满足以下条件:
      1. 以 -- 开头。
      2. 包含足够随机的字符,避免与数据内容冲突。
      3. 长度通常在 20-70 字符之间(无严格限制)。

示例
手动构造的请求头可能如下:http

Content-Type: multipart/form-data; boundary=---------------------------149742642616556 

3. 为什么会有两种形式?

(1) 浏览器与手动实现的差异
  • 浏览器
    为了统一性和可调试性,浏览器选择固定前缀(如 WebKitFormBoundary) + 随机字符串,方便开发者在开发者工具中快速识别 boundary 的来源。
  • 手动实现
    开发者或工具可能直接生成纯随机字符串,省略前缀,因为前缀对功能无影响,仅用于标识。
(2) 功能等价性
  • 无论 boundary 是 ----WebKitFormBoundaryABC123 还是 ---------------------------149742642616556,只要符合规范,服务器都能正确解析。
  • 关键点
    • 服务器只检查 boundary 的字符串是否匹配,不关心其命名方式。
    • 边界的唯一性和格式(--<字符串>)比前缀更重要。

4. 实际示例对比

浏览器生成的请求(带 WebKitFormBoundary

http

POST /upload HTTP/1.1 Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryABC123 ----WebKitFormBoundaryABC123\r\n Content-Disposition: form-data; name="file"; filename="test.txt"\r\n Content-Type: text/plain\r\n\r\n File content here...\r\n ----WebKitFormBoundaryABC123--\r\n 
手动生成的请求(纯数字 boundary)

http

POST /upload HTTP/1.1 Content-Type: multipart/form-data; boundary=---------------------------149742642616556 ---------------------------149742642616556\r\n Content-Disposition: form-data; name="file"; filename="test.txt"\r\n Content-Type: text/plain\r\n\r\n File content here...\r\n ---------------------------149742642616556--\r\n 

5. 常见问题解答

(1) 为什么 boundary 需要随机?
  • 如果 boundary 过于简单(如 ----abc),可能与数据内容重复,导致服务器解析错误。例如,若文件内容包含 ----abc,服务器会误认为是边界。
(2) 浏览器生成的 boundary 更安全吗?
  • 不是。浏览器生成的 boundary 和手动生成的在安全性上无本质区别,只要符合规范即可。浏览器的命名习惯仅为了方便调试。
(3) 如何手动生成合法的 boundary?

使用加密随机数生成器(如 Node.js 的 crypto.randomUUID())或简单拼接时间戳 + 随机字符:javascript

// 示例:生成类似 ---------------------------149742642616556 的 boundary const boundary = '---------------------------' + Date.now().toString(16); 

总结

  • WebKitFormBoundary 是浏览器生成的 boundary 前缀,属于命名习惯,非规范要求。
  • 纯数字 boundary(如 ---------------------------149742642616556)是手动或工具生成的合法字符串,功能与浏览器生成的完全等价。
  • 核心原则:boundary 只需满足 --<随机字符串> 的格式,确保唯一性即可,前缀无关紧要。

Read more

OpenClaw 全攻略:从入门到精通的 AI 智能体部署指南

OpenClaw 全攻略:从入门到精通的 AI 智能体部署指南

第一部分:认知篇 —— 什么是 OpenClaw? 1.1 定义与定位 OpenClaw(原名 Clawdbot / Moltbot)是一个本地优先、隐私至上、多渠道集成的自托管 AI 助手平台。它标志着人工智能从“对话式交互”迈入“自主行动”的第三阶段。 通俗理解: 传统 AI(如网页版 ChatGPT):你问一句,它答一句,像个顾问。 OpenClaw:你给它一个目标(如“帮我整理本月财报并发送给团队”),它能自己规划步骤、搜索数据、处理文件、发送邮件,像个员工。 1.2 核心架构:App、Gateway 与 CLI 要玩转 OpenClaw,必须理解它的三个核心组件: Gateway(网关)

UnityMCP+Claude+VSCode,构建最强AI游戏开发环境

UnityMCP+Claude+VSCode,构建最强AI游戏开发环境

* 前言 * 一、UnityMCP+Claude+VSCode,构建最强AI 游戏开发环境 * 1.1 介绍 * 1.2 使用说明及下载 * 二、VSCode配置 * 2.1 连接UnityMCP * 2.2 在VSCode中添加插件 * 2.3 Claude安装 * 2.4 VSCode MCP配置 * 2.5 使用Claude开发功能 * 三、相关问题 * 总结 前言 * 本篇文章来介绍使用 UnityMCP+Claude+VSCode,打造一个更智能、高效的游戏开发工作流。 * 借助MCP工具,Claude可以直接与Unity编辑器进行双向指令交互,开发者则可以直接使用自然语言进行Unity游戏开发。 * 这一组合充分利用了AI的代码生成、问题诊断与创意辅助能力,极大提升了Unity项目的开发效率与质量。 一、UnityMCP+Claude+

【前沿解析】2026年3月30日:AI推理能力与国产模型的双重突破——OpenAI o3/o4-mini推理优化与阿里Qwen3.5-Max-Preview盲测登顶重塑全球AI竞争格局

摘要:本文深入解析2026年3月29日至30日AI领域的双重突破。OpenAI深夜发布全新推理模型o3和o4-mini,在ARC-AGI测试中得分暴涨10倍,实现推理时计算与自然语言程序搜索创新;阿里巴巴通义千问Qwen3.5-Max-Preview在权威盲测平台LMArena登顶国产大模型榜首,超越GPT-5.4、Claude 4.5等海外旗舰模型,展示MoE架构与成本效率优势。本文涵盖技术原理、架构设计、代码实现及产业影响分析,为开发者提供全面的技术参考。 关键词:OpenAI o3, o4-mini, 推理优化, 阿里巴巴Qwen3.5-Max-Preview, LMArena盲测, MoE架构, ARC-AGI测试, 国产大模型 一、引言:AI领域迎来双重里程碑 2026年3月的最后一周,人工智能领域再次迎来密集的技术爆破。就在3月29日深夜,OpenAI突袭式发布全新推理模型o3和o4-mini,专门针对ARC-AGI这类"反刷榜"测试进行优化,在ARC-AGI-3测试中得分从GPT-5.4的0.26%直接飙升至2.8%,实现10倍突破。几乎同一

基于开源飞控pix的无人机装调与测试

基于开源飞控pix的无人机装调与测试

文章目录 * 前言 * 硬件使用说明 * 一、Hyper982 RTK模块 * 作为移动站使用 * 通过串口助手设置RTK参数(移动站) * 设置飞控参数(ArduPilot) * 设置飞控参数(PX4) * 二、HyperLte 4G图数传 * 资源下载 * 1、地面站软件和固件可执行文件 * 超维定制版HyperQGC(推荐) * NTRIP功能使用方法 * 基于超维定制版QGC和ArduPilot固件的领航跟随编队 * 多路视频流设置 * MQTT设置 * 地面站设置 * 4G模块配置 * MQTT服务器配置 * 飞控配置 * 海康威视相机云台控制 * Mission Planner地面站 * PX4固件可执行文件 * ArduPilot固件可执行文件 * 2、安装好环境的虚拟机 * 安装虚拟机 *