如何通过 Curl 从终端 / 命令行发布 JSON 数据以测试 Spring REST?

我使用 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;
}

答案

您需要将内容类型设置为 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

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


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

尝试将数据放入文件中,例如body.json ,然后使用

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

您可能会发现 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 选项

对于 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

它对我有用:

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

例如,创建一个 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

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

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

这对我来说很好。

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

哪里,

-X表示 http 动词。

--data要发送的数据。

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

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

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

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

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