如何使用cURL发布JSON数据?


2827

我使用Ubuntu,并在上面安装了cURL。我想用cURL测试我的Spring REST应用程序。我在Java端编写了POST代码。但是,我想用cURL对其进行测试。我正在尝试发布JSON数据。示例数据如下:

{"value":"30","type":"Tip 3","targetModule":"Target 3","configurationGroup":null,"name":"Configuration Deneme 3","description":null,"identity":"Configuration Deneme 3","version":0,"systemId":3,"active":true}

我使用以下命令:

curl -i \
    -H "Accept: application/json" \
    -H "X-HTTP-Method-Override: PUT" \
    -X POST -d "value":"30","type":"Tip 3","targetModule":"Target 3","configurationGroup":null,"name":"Configuration Deneme 3","description":null,"identity":"Configuration Deneme 3","version":0,"systemId":3,"active":true \
    http://localhost:8080/xx/xxx/xxxx

它返回此错误:

HTTP/1.1 415 Unsupported Media Type
Server: Apache-Coyote/1.1
Content-Type: text/html;charset=utf-8
Content-Length: 1051
Date: Wed, 24 Aug 2011 08:50:17 GMT

错误描述是这样的:

服务器拒绝了此请求,因为请求实体的格式不受请求方法()的请求资源支持。

Tomcat日志:“ POST / ui / webapp / conf / clear HTTP / 1.1” 415 1051

cURL命令的正确格式是什么?

这是我的Java辅助PUT代码(我已经测试了GET和DELETE,它们可以工作):

@RequestMapping(method = RequestMethod.PUT)
public Configuration updateConfiguration(HttpServletResponse response, @RequestBody Configuration configuration) { //consider @Valid tag
    configuration.setName("PUT worked");
    //todo If error occurs response.sendError(HttpServletResponse.SC_NOT_FOUND);
    return configuration;
}

6
检出spring 3.2.0发布请求的链接
2013年

8
有一篇不错的文章《使用Curl对RESTful微服务进行即席测试》,其中包含多个示例。
upitau

Answers:


4336

您需要将内容类型设置为application / json。但是-d发送Content-Type application/x-www-form-urlencoded,在Spring方面不接受。

查看curl手册页,我认为您可以使用-H

-H "Content-Type: application/json"

完整示例:

curl --header "Content-Type: application/json" \
  --request POST \
  --data '{"username":"xyz","password":"xyz"}' \
  http://localhost:3000/api/login

-H是的缩写--header-d代表--data

请注意,如果使用,-request POST则是可选的-d,因为该-d标志表示POST请求。


在Windows上,情况略有不同。请参阅评论主题。


262
对于Windows,json周围的单引号不起作用,我最终转义了双引号。 curl -X POST -H "Content-Type: application/json" -d "{ \"key1\": \"value1\" }" http://localhost:3000/api/method
2013年

37
对于Windows下的我,我需要使用这种格式的引号对引号进行转义"{ """key1""": """value1""" }"。同时这样的回答:stackoverflow.com/questions/18314796/...
chodorowicz

4
@chodorowicz太糟糕了!我只知道VB的语法!
肖恩·帕特里克·弗洛伊德

3
我在POST请求中遇到了问题,但是通过大写的“ Application / json”解决了该问题,因此如果遇到415错误,请检查大写。
WiteCastle 2014年

5
@ostrokach对不起,这浪费您的时间。语法在我发布时在OSX上对我来说很好用(尚未重试)。猜猜这是/只是一个平台差异。我想象这些支持来自那些帮助过的人。
亚当·塔特尔

564

尝试将您的数据放入文件中,body.json然后说出

curl -H "Content-Type: application/json" --data @body.json http://localhost:8080/ui/webapp/conf

12
您可能应该使用--data-binary选项而不是--data。可以期望客户端按原样发送数据,但是--data从输入中删除CR和LF。
h2stein 2014年

14
将cUrl与内联json字符串一起使用似乎是一场噩梦。需要替换双引号字符。使用这样的文件会更好。
Xtreme Biker 2014年

46
@在文件名之前添加一个字符很重要,否则它将无法正常工作。我只是花了20分钟在这种胡扯下敲打我的头……
Radu Murzea 2015年

3
这样,您还可以在文件上运行JSON lint,以查看解析JSON是否出错。
datashaman

4
在Windows上,您需要在文件名“ @ body.json”周围加上双引号
Stomf

101

您可能会发现resty有用:https//github.com/micha/resty

这是CURL的包装程序,可简化命令行REST请求。您将其指向您的API端点,它为您提供PUT和POST命令。(示例改编自首页)

$ resty http://127.0.0.1:8080/data #Sets up resty to point at your endpoing
$ GET /blogs.json                  #Gets http://127.0.0.1:8080/data/blogs.json
                                   #Put JSON
$ PUT /blogs/2.json '{"id" : 2, "title" : "updated post", "body" : "This is the new."}'
                                   # POST JSON from a file
$ POST /blogs/5.json < /tmp/blog.json

另外,通常仍然需要添加Content Type标头。但是,您可以执行一次此操作,以设置默认值,即每个站点的每个方法添加配置文件:设置默认的RESTY选项


93

对于Windows,对-d值使用单引号对我来说不起作用,但是在更改为双引号后它确实起作用。另外,我需要在花括号中转义双引号。

也就是说,以下操作无效:

curl -i -X POST -H "Content-Type: application/json" -d '{"key":"val"}' http://localhost:8080/appname/path

但是以下方法有效:

curl -i -X POST -H "Content-Type: application/json" -d "{\"key\":\"val\"}" http://localhost:8080/appname/path

5
仅供参考-长得像你错过了周围的JSON体结束的双引号
acanby

3
对于Windows上的我来说,“围绕数据不起作用,而没有引号起作用
rodedo 16-10-17

3
如果你正在使用PowerShell的,看到这个答案。
rsenna '18

86

它对我有用:

curl -H "Accept: application/json" -H "Content-type: application/json" -X POST -d '{"id":100}' http://localhost/api/postJsonReader.do

它很高兴地映射到了Spring控制器:

@RequestMapping(value = "/postJsonReader", method = RequestMethod.POST)
public @ResponseBody String processPostJsonData(@RequestBody IdOnly idOnly) throws Exception {
        logger.debug("JsonReaderController hit! Reading JSON data!"+idOnly.getId());
        return "JSON Received";
}

IdOnly是带有id属性的简单POJO


56

例如,创建一个JSON文件params.json,并向其中添加以下内容:

[
    {
        "environment": "Devel",
        "description": "Machine for test, please do not delete!"
    }
]

然后运行以下命令:

curl -v -H "Content-Type: application/json" -X POST --data @params.json -u your_username:your_password http://localhost:8000/env/add_server

42

我只是遇到了同样的问题。我可以通过指定解决

-H "Content-Type: application/json; charset=UTF-8"

37

这对我来说很好。

curl -X POST --data @json_out.txt http://localhost:8080/

哪里,

-X 表示http动词。

--data 表示您要发送的数据。


5
-X POST是在这个例子中多余的
软件工程师

31

您可以使用Postman及其直观的GUI来汇编cURL命令。

  1. 安装并启动邮递员
  2. 键入您的URL,帖子正文,请求标题等。
  3. 点击 Code
  4. 选择cURL从下拉列表
  5. 复制并粘贴您的cURL命令

注意:下拉列表中有多个选项可以自动生成请求,这就是为什么我认为我的帖子首先是必需的。


6
没有意识到该功能已包含在Postman中。感谢您指出!
ariestav

29

使用CURL Windows,请尝试以下操作:

curl -X POST -H "Content-Type:application/json" -d "{\"firstName\": \"blablabla\",\"lastName\": \"dummy\",\"id\": \"123456\"}" http-host/_ah/api/employeeendpoint/v1/employee

28

您可以使用邮递员转换为CURL在此处输入图片说明

在此处输入图片说明


1
非常感谢@ forever-LA,这对我来说是一条
拯救

24

HTTPie是推荐的替代方法,curl因为您可以

$ http POST http://example.com/some/endpoint name=value name1=value1

默认情况下,它使用JSON,它将处理为您设置必要的标头以及将数据编码为有效JSON的情况。还有:

Some-Header:value

用于标题,以及

name==value

查询字符串参数。如果您有大量数据,则还可以从文件中进行JSON编码读取:

 field=@file.txt

20

如果您要针对RESTful接口测试大量JSON发送/响应,则可能需要查看适用于Chrome 的Postman插件(允许您手动定义Web服务测试)及其基于Node.js的Newman命令在线伴侣(允许您针对邮递员测试的“集合”自动执行测试。)免费和开放!


18

这对我来说很好,另外使用了BASIC身份验证:

curl -v --proxy '' --basic -u Administrator:password -X POST -H "Content-Type: application/json"
        --data-binary '{"value":"30","type":"Tip 3","targetModule":"Target 3","configurationGroup":null,"name":"Configuration Deneme 3","description":null,"identity":"Configuration Deneme 3","version":0,"systemId":3,"active":true}'
        http://httpbin.org/post

当然,没有SSL和经过检查的证书,切勿使用BASIC身份验证。

今天,我再次在Windows上使用Cygwin的cURL 7.49.1遇到了这个问题...当使用JSON参数--data或将其--data-binary与JSON参数一起使用时,cURL会感到困惑,并且会将{}JSON中的解释为URL模板。添加一个-g参数以关闭cURL globing修复了该问题。

另请参阅传递带有方括号的URL以进行卷曲


17

您还可以将JSON内容放入文件中,然后使用该--file-upload选项通过标准输入将其传递给curl ,如下所示:

 echo 'my.awesome.json.function({"do" : "whatever"})' | curl -X POST "http://url" -T -


10

我正在使用以下格式来测试Web服务器。

use -F 'json data'

让我们假设这种JSON dict格式:

{
    'comment': {
        'who':'some_one',
        'desc' : 'get it'
    }
}

完整的例子

curl -XPOST your_address/api -F comment='{"who":"some_one", "desc":"get it"}'

6

使用-d选项添加有效负载

curl -X POST \
http://<host>:<port>/<path> \
-H 'Accept: application/json' \
-H 'Content-Type: application/json' \
-d '{
"foo": "bar",
"lorem": "ipsum"
}'

此外:

使用-X POST使用POST方法

使用-H'Accept:application / json'添加接受类型标头

使用-H'Content-Type:application / json'添加内容类型标头


我尝试使用它,但遇到{“错误”:[“未提供数据”]}错误。
Suresh

6

这在Windows10上对我有用

curl -d "{"""owner""":"""sasdasdasdasd"""}" -H "Content-Type: application/json" -X  PUT http://localhost:8080/api/changeowner/CAR4

5

请检查此工具。它可以帮助您轻松创建卷发片段。

curl -XGET -H "Accept: application/json" -d "{\"value\":\"30\",\"type\":\"Tip 3\",\"targetModule\":\"Target 3\",\"configurationGroup\":null,\"name\":\"Configuration Deneme 3\",\"description\":null,\"identity\":\"Configuration Deneme 3\",\"version\":0,\"systemId\":3,\"active\":true}" "http://localhost:8080/xx/xxx/xxxx"

5

如果要包含动态数据,这是另一种方法。

#!/bin/bash

version=$1
text=$2
branch=$(git rev-parse --abbrev-ref HEAD)
repo_full_name=$(git config --get remote.origin.url | sed 's/.*:\/\/github.com\///;s/.git$//')
token=$(git config --global github.token)

generate_post_data()
{
  cat <<EOF
{
  "tag_name": "$version",
  "target_commitish": "$branch",
  "name": "$version",
  "body": "$text",
  "draft": false,
  "prerelease": false
}
EOF
}

echo "Create release $version for repo: $repo_full_name branch: $branch"
curl --data "$(generate_post_data)" "https://api.github.com/repos/$repo_full_name/releases?access_token=$token"

1
你救了我的命!
Abhimanyu

4

我知道,这个问题已经得到了很多回答,但我想分享一下我遇到的问题:

curl -X POST http://您的服务器端点 -H“ Content-Type:application / json” -d @ path-of-your-json-file.json

看,我所做的一切都正确,只有一件事-在JSON文件路径之前错过了“ @”。

我在互联网上找到了一个相关的入门文档-https: //gist.github.com/subfuzion/08c5d85437d5d4f00e58

希望对少数人有帮助。谢谢


1

如果将SWAGGER配置为您的Spring Boot应用程序,并从应用程序中调用任何API,那么您也可以看到该CURL请求。

我认为这是通过CURL生成请求的简单方法。


By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.