目录

Windows-11下Git-Bash执行cURL脚本400问题CMDPowerShell不能执行多行文本等问题记录及解决方案

Windows 11下Git Bash执行cURL脚本400问题、CMD/PowerShell不能执行多行文本等问题记录及解决方案

问题

在Postman里可成功执行的POST请求:

https://i-blog.csdnimg.cn/direct/56ae829ab145403abc8f53869ce7d99f.png

找到Postman的Code

https://i-blog.csdnimg.cn/direct/8912508a2389492d8a2b52834bc6d7a6.png

因为cURL基本上算是行业标准,所以Postman默认选中cURL,支持切换不同的开发语言:

https://i-blog.csdnimg.cn/direct/a52c8a87196a4f098c6ae4deaf803ac7.png

点击上图右上角的复制按钮,得到cURL脚本。

Windows 11家庭版,打开Git Bash客户端,版本为:

git version 2.47.1.windows.1

https://i-blog.csdnimg.cn/direct/240f4168dba8415a97a381c1a2fb8b64.png

执行上述cURL脚本异常:

https://i-blog.csdnimg.cn/direct/7c45a4e8305349c8971ef2abfd4d447e.png

报错信息:

{"code":400,"msg":"JSON parse error: Invalid UTF-8 start byte 0xb4; nested exception is com.fasterxml.jackson.core.JsonParseException: Invalid UTF-8 start byte 0xb4\n at [Source: (org.springframework.util.StreamUtils$NonClosingInputStream); line: 3, column: 18]"}

分析

根据上面几行简短的报错信息,提取几个关键内容:

  • code=400 :表明这是客户端异常,此处的客户端是Git Bash;
  • JsonParseException和StreamUtils:表明服务端确实有接收到客户端提交的请求,要不然客户端也无法得知Jackson框架里的类JsonParseException,当然也无法得知Spring框架里的StreamUtils工具类;
  • 报错原因是非法JSON: JSON parse error
  • 编码异常: Invalid UTF-8 start byte 0xb4

分析起来,看起来头头是道,怎么解决问题呢?

排查

遇到问题时,还是习惯性将问题抛给ChatGPT,结果这次是真的全程被ChatGPT的胡言乱语给糊弄,浪费不少时间。

https://i-blog.csdnimg.cn/direct/9448684605624278affdd1b2e97aa344.png

一一尝试:

  • 很明确是小写双引号,不是大写双引号;

  • 将上述cURL脚本使用txt文件保存,并保存为不带 的格式,没有解决问题;

    https://i-blog.csdnimg.cn/direct/411e94b00f554c6289a340c8bd2978bf.png

  • 报错提示是第三行 line: 3, column: 18 ,好像是 min_score 字段,去掉引号试试,还是报错:

    https://i-blog.csdnimg.cn/direct/2f076bc80ff54bbd8e53ffa4f8ab766a.png

  • --data-binary 还是报错:

    https://i-blog.csdnimg.cn/direct/b009929718f64491ab03b64e1987bc62.png

方法一

反复尝试+试错,浪费不少时间,ChatGPT终于给出一个可行的解决方案:

https://i-blog.csdnimg.cn/direct/76af7efb5c7542b4a6c15eecf0f16ac0.png

也就是在Git Bash执行的目录下,新增一个 payload.json 文件,内容就是POST请求的requestBody:

{
    "retriever_type": "TEXT",
    "question": "大模型技术如何帮助数据中心实现高效减碳?",
    "min_score": "0.2",
    "max_results": "10"
}

然后将命令:

--data '{
    "retriever_type": "TEXT",
    "question": "大模型技术如何帮助数据中心实现高效减碳?",
    "min_score": "0.2",
    "max_results": "10"
}'

修改为(其他部分不变): --data @payload.json

执行效果:

https://i-blog.csdnimg.cn/direct/dc6a83df26a6470c894102b98f2d4e4d.png

方法二

为了执行一个在Postman可以成功执行的cURL脚本,我需要另存为一个JSON文件,感觉非常反人类。于是继续追问ChatGPT,给出一个不使用文件的方法:

printf '%s' '{
  "retriever_type": "TEXT",
  "question": "大模型技术如何帮助数据中心实现高效减碳?",
  "min_score": "0.2",
  "max_results": "10"
}' | curl --location 'http://api.test.tesla.com/rag_online/rag/retrieval' \
  --header 'tesla-token: 1111222233334444' \
  --header 'Content-Type: application/json' \
  --data @-

和上面的解决方法非常类似。

GET

Git Bash客户端下执行cURL GET命令没有问题,只是在执行POST命令才有问题。

https://i-blog.csdnimg.cn/direct/a3e0fc9f5c644c7ba0512bc408e1ad7f.png

CMD/PowerShell

既然Git Bash客户端不能用,于是将注意力放在其他客户端。

打开cmd或PowerShell,粘帖cURL脚本,结果给我提示:您将粘贴包含多行的文本。如果将此文本粘贴到 shell 中,则可能会导致命令意外执行。是否继续?

https://i-blog.csdnimg.cn/direct/2419246610ef4dae966b7718afea9ed2.png

如上图所示,CMD和PowerShell无法识别多行cURL脚本,会拆分成多行,当然会执行失败。

怎么解决?

ChatGPT又让我失望

https://i-blog.csdnimg.cn/direct/b870f0a784954e67914c41b77300b216.png

https://i-blog.csdnimg.cn/direct/fe9767ac364c4aa999c05e2b16c79f18.png

并不能解决问题。

Google找到一篇类似的报错 。

TODO:未解决。

Mac

上述cURL脚本在同事的Mac开发机上(使用的终端未知),可执行成功。

解决方案

Git Bash

如果是GET请求,直接可使用Git Bash。但是对于POST请求,如果坚持要使用Git Bash客户端,有两种方法:

  • 使用文件
curl --location 'http://api.test.tesla.com/rag_online/rag/retrieval' \
--header 'tesla-token: 1111222233334444' \
--header 'Content-Type: application/json' \
--data @payload.json
  • 使用管道符
printf '%s' '{
  "retriever_type": "TEXT",
  "question": "大模型技术如何帮助数据中心实现高效减碳?",
  "min_score": "0.2",
  "max_results": "10"
}' | curl --location 'http://api.test.tesla.com/rag_online/rag/retrieval' \
  --header 'ecmas-token: 1111222233334444' \
  --header 'Content-Type: application/json' \
  --data @-

https://i-blog.csdnimg.cn/direct/a919d900f4be48ba89ef36d443cdd86a.png

Mac

Mac比Windows强,受开发者青睐,不是没有原因的。

WSL

Windows 8不知道什么时候开始支持WSL,另外貌似有不少 ,Windows 10/11好像也不是一开始就支持WSL的。

总而言之,如果可以的话,建议升级Windows版本,安装WSL,比CMD、PowerShell功能强大:

https://i-blog.csdnimg.cn/direct/c8993323ffbf454b91f6bf28d88e6809.png

使用WSL可执行多行cURL脚本。当然,WSL是一个Ubuntu系统,默认自带cURL命令。

关于WSL,参考我写的另一篇 。

参考

  • ChatGPT