SpringMVC @RequestBody自動轉(zhuǎn)json Http415錯誤的解決
SpringMVC @RequestBody自動轉(zhuǎn)json Http415錯誤
項目中想用@RequestBody直接接收json串轉(zhuǎn)成對象
網(wǎng)上查了使用方法,看著非常簡單,不過經(jīng)過測試很快發(fā)現(xiàn)頁面直接報415錯誤。
<body> ? ? ? ? <h1>HTTP Status 415 - </h1> ? ? ? ? <HR size="1" noshade="noshade"> ? ? ? ? ? ? <p> ? ? ? ? ? ? ? ? <b>type</b> Status report ? ? ? ? ? ? </p> ? ? ? ? ? ? <p> ? ? ? ? ? ? ? ? <b>message</b> ? ? ? ? ? ? ? ? <u></u> ? ? ? ? ? ? </p> ? ? ? ? ? ? <p> ? ? ? ? ? ? ? ? <b>description</b> ? ? ? ? ? ? ? ? <u>The server refused this request because the request entity is in a format not supported by the requested resource for the requested method.</u> ? ? ? ? ? ? </p> ? ? ? ? ?<HR size="1" noshade="noshade"> ? ? ? ? ? ? <h3>Apache Tomcat/6.0.41</h3> </body>
經(jīng)過一通查,多半的解決方法實說header里的 Content-Type 一定 application/json
但是問題依然沒有解決。
最后在《Spring in Action》里找到一個信息
有兩個前提條件:
The request’sContent-Typeheader must be set toapplication/json.
The JacksonJSONlibrary must be available on the application’s classpath.
我滿足了第一個,所以在classpath中添加了一個jar。問題解決了。
? ? ? ? <dependency> ? ? ? ? ? ? <groupId>com.fasterxml.jackson.core</groupId> ? ? ? ? ? ? <artifactId>jackson-databind</artifactId> ? ? ? ? ? ? <version>2.5.3</version> ? ? ? ? </dependency>
所以如果大家遇到了同樣的問題,可以先排除一下這兩個因素。
還有一種情況,在以上兩個條件都滿足的情況下,還是報同樣的錯誤。
在springmvc的配置文件中必須有:
? ? <!-- 默認的注解映射的支持 --> ? ? <mvc:annotation-driven />
如果沒有這個配置也是會報這個錯的!
為什么會引入jackson-databind包呢,因為默認的配置會用到:
com.fasterxml.jackson.databind.ObjectMapper
<mvc:message-converters> ?? ??? ??? ?<bean ?? ??? ??? ??? ?class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> ?? ??? ??? ??? ?<property name="objectMapper"> ?? ??? ??? ??? ??? ?<bean class="com.fasterxml.jackson.databind.ObjectMapper"> ?? ??? ??? ??? ??? ??? ?<property name="dateFormat"> ?? ??? ??? ??? ??? ??? ??? ?<bean class="java.text.SimpleDateFormat"> ?? ??? ??? ??? ??? ??? ??? ??? ?<constructor-arg type="java.lang.String" value="yyyy-MM-dd HH:mm:ss" /> ?? ??? ??? ??? ??? ??? ??? ?</bean> ?? ??? ??? ??? ??? ??? ?</property> ?? ??? ??? ??? ??? ?</bean> ?? ??? ??? ??? ?</property> ?? ??? ??? ?</bean> ?? ??? ?</mvc:message-converters>
SpringMVC @RequestBody使用
Spring mvc是一個非常輕量的mvc框架,注解可以大大減少配置,讓請求的攔截變得比較簡單。這次記錄下@RequestBody 注解接收參數(shù)尤其是數(shù)組參數(shù)的用法。
關(guān)于容器的配置不再多說,這里寫出spring-servlet.xml的sechme:
<?xml version="1.0" encoding="UTF-8" ?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:task="http://www.springframework.org/schema/task" xsi:schemaLocation="http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.0.xsd"> <!-- 掃描包注解 --> <context:component-scan base-package="xxxx"></context:component-scan> <!-- mvc注解功能啟動 --> <mvc:annotation-driven /> </beans>
只要對應(yīng)包名下面的添加注解即可掃描到對應(yīng)的控制器,一般采用@Controller
- RequestBody接收基本類型
@Controller public class TestController { // url請求攔截 @RequestMapping("test/test.do") @ResponseBody // 返回參數(shù)為JSON public void test(@RequestBody String name) { System.out.println("getParams : " + name); } }
@RequestBody只要接收POST請求Body里的數(shù)據(jù)。
這樣發(fā)送請求,即可在java控制臺中打印:
getParams : {"name":"micro"}
- @RequestBody接收基本數(shù)組
然后我們接收基本類型數(shù)組:
@RequestMapping("test/test.do") @ResponseBody public void test(@RequestBody List<String> nameList) { System.out.println("getParams : " + nameList); }
這樣即可獲取到參數(shù),不要body里寫成了{“nameList”:[“name1”,“name2”]}這樣會拋出異常。
@RequestBody是對應(yīng)的POST請求的body,body即是獲取的參數(shù),如果想通過參數(shù)去獲取,則要使用@RequestParams 注解:
@RequestMapping("test/test.do") @ResponseBody public void test(@RequestParam("name") String name) { System.out.println("getParams : " + name); }
注意是GET請求,參數(shù)直接放到URL后面,這樣就可以使用@RequestParams獲取到對應(yīng)參數(shù)名的參數(shù)值。
如果是復(fù)雜的對象。
@RequestBody的使用。
定義model:
class Person { private Long id; private String name; // setter getter }
- @RequestBody接收復(fù)雜對象
接收參數(shù)的方式
@RequestMapping("test/test.do") @ResponseBody public void test(@RequestBody Person person) { System.out.println("getParams : " + person.getId() + " ," + person.getName()); }
即可獲取到參數(shù),body里的參數(shù)會自動匹配到person的屬性并賦值。
注意名字要與對象的屬性變量名一致。否則獲取不到參數(shù),例如這里就不能在body里寫成{“i”:1,“name”:“micro”},這樣獲取到person的id為null。
- @RequestBody接收復(fù)雜對象數(shù)組
如果是復(fù)雜對象數(shù)組:
@RequestMapping("test/test.do") @ResponseBody public void test(@RequestBody List<Person> personList) { for (Person p : personList) { System.out.println(p.getId() + " ," + p.getName()); } }
請求方式如下,注意body里的格式是[]數(shù)組。
控制臺打?。?/p>
1 ,micro
2 ,micro2
總結(jié)
即完成了@RequestBody接收各種類型的參數(shù)。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java中json與javaBean幾種互轉(zhuǎn)的講解
今天小編就為大家分享一篇關(guān)于Java中json與javaBean幾種互轉(zhuǎn)的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03分頁技術(shù)原理與實現(xiàn)之Java+Oracle代碼實現(xiàn)分頁(二)
這篇文章主要介紹了分頁技術(shù)原理與實現(xiàn)的第二篇:Java+Oracle代碼實現(xiàn)分頁,感興趣的小伙伴們可以參考一下2016-06-06Java實現(xiàn)Excel導(dǎo)入導(dǎo)出操作詳解
在平常的辦公工作中,導(dǎo)入導(dǎo)出excel數(shù)據(jù)是常見的需求,今天就來看一下通過Java如何來實現(xiàn)這個功能,感興趣的朋友可以了解下2022-02-02使用OpenFeign實現(xiàn)服務(wù)調(diào)用的方法詳解
OpenFeign是運行在客戶端的聲明式服務(wù)調(diào)用的框架,通過聲明接口的方式來達到對服務(wù)的調(diào)用,本文就來和大家講講如何使用OpenFeign實現(xiàn)服務(wù)調(diào)用吧2023-06-06