Как опубликовать данные JSON с завитком из терминала / командной строки для тестирования весеннего отдыха?

Я использую Ubuntu и установил на нем Curl. Я хочу протестировать приложение Spring REST с помощью Curl. Я написал свой почтовый код на стороне 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?

EDIT:

Это мой 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;
} 

20 ответов


вам нужно установить тип контента в application / json. Но!--13-->-d отправляет тип контента application/x-www-form-urlencoded, который не принят на стороне весны.

смотреть на!--17-->curl man page, я думаю, вы можете использовать -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 is дополнительно если вы используете -d, как -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

это обертка круглый завиток, который упрощает запросы командной строки 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

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


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

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.


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

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

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

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

здесь

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

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


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

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

используя окна CURL, попробуйте следующее:

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

Если вы тестируете много JSON send / responses против интерфейса RESTful, вы можете проверить почтальон плагин для Chrome (который позволяет вручную определять тесты веб-служб) и его узел.ИС-основе Ньюман компаньон командной строки (который позволяет автоматизировать тесты против "коллекций" тестов Postman.) Бесплатно и открыто!


можно использовать почтальон С интуитивно понятным GUI, чтобы собрать ваш .

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

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


это хорошо сработало для меня, дополнительно используя базовую аутентификацию:

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 и проверенного сертификата.

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

см. также передача URL-адреса в скобках для curl.


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

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

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

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

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

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

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

Some-Header:value

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

name==value

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

 field=@file.txt

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

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

для данных json

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

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

curl -X POST -F "data=@/Users/vishvajitpathak/Desktop/screen_1.png" http://localhost:8080/upload --insecure

в случае, если вы не хотите испортить https и http:

или просто

curl -X POST -F "data=@/Users/vishvajitpathak/Desktop/screen_1.png" http://localhost:8080/upload


Я использую 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 "data=@/users/suchi/dekstop/JSON_request.txt" hostname:port/api

создать файл 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

вы можете передать расширение формата, который вы хотите, как конец url. как http://localhost:8080/xx/xxx/xxxx.в JSON

или

http://localhost:8080/xx/xxx/xxxx.в XML

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