raw - Как отправлять данные POST JSON с помощью Curl из терминала/командной строки для тестирования Spring REST?




php curl set json data (14)

Я использую Ubuntu и устанавливаю Curl на нем. Я хочу протестировать приложение Spring REST с помощью Curl. Я написал свой POST-код на стороне Java. Тем не менее, я хочу проверить его с помощью 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;
} 

В качестве примера создайте файл 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

Вам необходимо установить тип контента для приложения / json. Но -d отправляет application/x-www-form-urlencoded Content-Type application/x-www-form-urlencoded , которое не принимается со стороны Spring.

Глядя на страницу curl man , я думаю, вы можете использовать -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 все немного отличается. См. Комментарий.


Вы можете найти 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


Вы можете передать расширение желаемого формата в качестве конца URL-адреса. например http://localhost:8080/xx/xxx/xxxx .json

или же

http://localhost:8080/xx/xxx/xxxx .xml

Примечание: вам нужно добавить зависимости Jackson и jaxb maven в вашем pom.


Для данных json

curl -H "Content-Type: application/json" -X POST -d '{"params1":"value1","param2":"value2"}' http://localhost:8080/api

Если вы хотите опубликовать файл

curl -X POST -F "[email protected]/Users/vishvajitpathak/Desktop/screen_1.png" http://localhost:8080/upload --insecure

Если вы не хотите испортить https и http:

ИЛИ Просто,

curl -X POST -F "[email protected]/Users/vishvajitpathak/Desktop/screen_1.png" http://localhost:8080/upload


Если вы тестируете много сообщений и ответов JSON на интерфейс RESTful, вы можете проверить подключаемый модуль Postman для Chrome (который позволяет вам вручную определять тесты веб-сервиса) и его команду Newman Node.js -лайн-компаньон (который позволяет вам автоматизировать тесты против «коллекций» тестов Postman.) И бесплатные, и открытые!


Немного поздно для вечеринки, но я не вижу, что это опубликовано, так что здесь вы можете добавить свой json в файл и передать его завиту, используя параметр -file-upload через стандартный ввод, например:

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

Он работал для меня, используя:

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 - это простой POJO с свойством id.


Создайте JSON-файл «MyData.json» и добавьте контент:

[
    {
        "Key_one": "Value_one",
        "Key_two": "Value_two",
        "Key_three": "Value_three"
    }
]

После этого вам нужно выполнить следующую команду:

curl -v -H "Content-Type: application/json" -X POST --data @MyData.json -u USERNAME:PASSWORD http://localhost:8000/env/add_server

Это сработало для меня, дополнительно используя 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

Конечно, вы никогда не должны использовать аутентификацию BASIC без SSL и проверенный сертификат.

Я столкнулся с этим снова сегодня, используя cURL 7.46.1 для Cygwin для Windows ... И при использовании --data или --data-binary с аргументом JSON cURL запутался и интерпретировал {} в JSON как URL-адрес шаблон. Добавление аргумента -g для отключения cURL globbing исправлено.

См. Также « Передача URL с скобками» .


Это сработало для меня:

curl -H "Content-Type: application/json" -X POST -d @./my_json_body.txt http://192.168.1.1/json

Я использую JSON в своем приложении и просто:

curl -X POST -H "Content-Type:application/json" -d '{"params1":"value1","params2":"value2"} hostname:port/api

Но если у вас есть большое количество параметров, вы всегда предпочитаете использовать файл с телом запроса JSON, как показано ниже:

curl -X POST -H "Content-Type:application/json" -F "[email protected]/users/suchi/dekstop/JSON_request.txt" hostname:port/api

Я просто столкнулся с той же проблемой. Я мог бы решить это, указав

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

HTTPie - рекомендуемая альтернатива HTTPie потому что вы можете сделать

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

Он говорит по умолчанию JSON и будет обрабатывать как настройку необходимого заголовка для вас, так и данные кодирования как действительные JSON. Существует также:

Some-Header:value

для заголовков и

name==value

для параметров строки запроса. Если у вас большой объем данных, вы также можете прочитать его из файла, если он закодирован JSON:

 [email protected]




curl