Използвам 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;
}
Трябва да зададете тип на съдържанието application/json. Но -d
изпраща Content-Type application/x-www-form-urlencoded
, който не се приема от страна на Spring's.
Поглеждайки към 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
е незадължително, ако използвате -d
, тъй като флагът -d
предполага POST заявка.
При Windows нещата са малко по-различни. Вижте темата с коментари.
Току-що се сблъсках със същия проблем. Мога да го реша, като посоча
-H "Content-Type: application/json; charset=UTF-8"