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

Я использую 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?

Это мой код PUT стороне Java (я проверил 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;
}

Ответы

Ответ 1

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

Глядя на -H страницу 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 все немного по-другому. Смотрите ветку комментариев.

Ответ 2

Попробуйте поместить ваши данные в файл, скажем body.json, а затем используйте

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

Ответ 3

Вы можете найти полезную для отдыха: 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 варианты

Ответ 4

Для 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

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

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.

Ответ 6

Например, создайте файл 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

Ответ 7

Это сработало хорошо для меня.

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

Где

-X Означает http-глагол.

--data Означает данные, которые вы хотите отправить.

Ответ 8

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

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

Ответ 9

Используя CURL Windows, попробуйте следующее:

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

Ответ 10

Вы можете использовать Postman с его интуитивно понятным графическим интерфейсом для сборки вашей команды cURL.

  1. Установить и запустить почтальон
  2. Введите свой URL, текст сообщения, заголовки запроса и т.п.
  3. Нажмите на Code
  4. Выберите cURL из выпадающего списка
  5. скопируйте и вставьте вашу команду cURL

Примечание. В раскрывающемся списке есть несколько вариантов автоматической генерации запросов, поэтому я решил, что мой пост был необходим в первую очередь.

Ответ 11

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

Ответ 12

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

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

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

Some-Header:value

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

name==value

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

 [email protected]

Ответ 13

Это сработало для меня, дополнительно используя аутентификацию 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 и проверенный сертификат.

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

См. также Передача URL с скобками для завивки.

Ответ 14

Вы также можете поместить содержимое JSON в файл и передать его в curl, используя опцию --file-upload через стандартный ввод, например:

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

Ответ 15

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

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

Ответ 16

Я использую следующий формат для тестирования с помощью веб-сервера.

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"}'

Ответ 17

Вы можете использовать почтальона для конвертации в CURL enter image description here

enter image description here

Ответ 18

Для данных 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

Ответ 19

Используйте опцию -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 для добавления заголовка типа контента

Ответ 20

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

Ответ 21

Пожалуйста, проверьте этот инструмент. Это поможет вам легко создавать фрагменты скручивания.

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"

Ответ 22

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

или же

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

Примечание: вам нужно добавить зависимости Jackson и JaxB Maven в вашем POM.