SpringMVC @RequestBody自動(dòng)轉(zhuǎn)json Http415錯(cuò)誤的解決
SpringMVC @RequestBody自動(dòng)轉(zhuǎn)json Http415錯(cuò)誤
項(xiàng)目中想用@RequestBody直接接收json串轉(zhuǎn)成對(duì)象
網(wǎng)上查了使用方法,看著非常簡(jiǎn)單,不過(guò)經(jīng)過(guò)測(cè)試很快發(fā)現(xiàn)頁(yè)面直接報(bào)415錯(cuò)誤。
<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)過(guò)一通查,多半的解決方法實(shí)說(shuō)header里的 Content-Type 一定 application/json
但是問(wèn)題依然沒(méi)有解決。
最后在《Spring in Action》里找到一個(gè)信息
有兩個(gè)前提條件:
The request’sContent-Typeheader must be set toapplication/json.
The JacksonJSONlibrary must be available on the application’s classpath.
我滿足了第一個(gè),所以在classpath中添加了一個(gè)jar。問(wèn)題解決了。
? ? ? ? <dependency> ? ? ? ? ? ? <groupId>com.fasterxml.jackson.core</groupId> ? ? ? ? ? ? <artifactId>jackson-databind</artifactId> ? ? ? ? ? ? <version>2.5.3</version> ? ? ? ? </dependency>
所以如果大家遇到了同樣的問(wèn)題,可以先排除一下這兩個(gè)因素。
還有一種情況,在以上兩個(gè)條件都滿足的情況下,還是報(bào)同樣的錯(cuò)誤。
在springmvc的配置文件中必須有:
? ? <!-- 默認(rèn)的注解映射的支持 --> ? ? <mvc:annotation-driven />
如果沒(méi)有這個(gè)配置也是會(huì)報(bào)這個(gè)錯(cuò)的!
為什么會(huì)引入jackson-databind包呢,因?yàn)槟J(rèn)的配置會(huì)用到:
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是一個(gè)非常輕量的mvc框架,注解可以大大減少配置,讓請(qǐng)求的攔截變得比較簡(jiǎn)單。這次記錄下@RequestBody 注解接收參數(shù)尤其是數(shù)組參數(shù)的用法。
關(guān)于容器的配置不再多說(shuō),這里寫(xiě)出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注解功能啟動(dòng) -->
<mvc:annotation-driven />
</beans>
只要對(duì)應(yīng)包名下面的添加注解即可掃描到對(duì)應(yīng)的控制器,一般采用@Controller
- RequestBody接收基本類型
@Controller
public class TestController {
// url請(qǐng)求攔截
@RequestMapping("test/test.do")
@ResponseBody // 返回參數(shù)為JSON
public void test(@RequestBody String name) {
System.out.println("getParams : " + name);
}
}
@RequestBody只要接收POST請(qǐng)求Body里的數(shù)據(jù)。

這樣發(fā)送請(qǐng)求,即可在java控制臺(tái)中打?。?/p>
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里寫(xiě)成了{(lán)“nameList”:[“name1”,“name2”]}這樣會(huì)拋出異常。
@RequestBody是對(duì)應(yīng)的POST請(qǐng)求的body,body即是獲取的參數(shù),如果想通過(guò)參數(shù)去獲取,則要使用@RequestParams 注解:
@RequestMapping("test/test.do")
@ResponseBody
public void test(@RequestParam("name") String name) {
System.out.println("getParams : " + name);
}

注意是GET請(qǐng)求,參數(shù)直接放到URL后面,這樣就可以使用@RequestParams獲取到對(duì)應(yīng)參數(shù)名的參數(shù)值。
如果是復(fù)雜的對(duì)象。
@RequestBody的使用。
定義model:
class Person {
private Long id;
private String name;
// setter getter
}
- @RequestBody接收復(fù)雜對(duì)象
接收參數(shù)的方式
@RequestMapping("test/test.do")
@ResponseBody
public void test(@RequestBody Person person) {
System.out.println("getParams : " + person.getId() + " ," + person.getName());
}
即可獲取到參數(shù),body里的參數(shù)會(huì)自動(dòng)匹配到person的屬性并賦值。
注意名字要與對(duì)象的屬性變量名一致。否則獲取不到參數(shù),例如這里就不能在body里寫(xiě)成{“i”:1,“name”:“micro”},這樣獲取到person的id為null。
- @RequestBody接收復(fù)雜對(duì)象數(shù)組
如果是復(fù)雜對(duì)象數(shù)組:
@RequestMapping("test/test.do")
@ResponseBody
public void test(@RequestBody List<Person> personList) {
for (Person p : personList) {
System.out.println(p.getId() + " ," + p.getName());
}
}
請(qǐng)求方式如下,注意body里的格式是[]數(shù)組。

控制臺(tái)打?。?/p>
1 ,micro
2 ,micro2
總結(jié)
即完成了@RequestBody接收各種類型的參數(shù)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java中json與javaBean幾種互轉(zhuǎn)的講解
今天小編就為大家分享一篇關(guān)于Java中json與javaBean幾種互轉(zhuǎn)的講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03
分頁(yè)技術(shù)原理與實(shí)現(xiàn)之Java+Oracle代碼實(shí)現(xiàn)分頁(yè)(二)
這篇文章主要介紹了分頁(yè)技術(shù)原理與實(shí)現(xiàn)的第二篇:Java+Oracle代碼實(shí)現(xiàn)分頁(yè),感興趣的小伙伴們可以參考一下2016-06-06
Java實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出操作詳解
在平常的辦公工作中,導(dǎo)入導(dǎo)出excel數(shù)據(jù)是常見(jiàn)的需求,今天就來(lái)看一下通過(guò)Java如何來(lái)實(shí)現(xiàn)這個(gè)功能,感興趣的朋友可以了解下2022-02-02
Java實(shí)現(xiàn)解析.xlsb文件的示例代碼
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)解析.xlsb文件的相關(guān)方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的可以了解一下2023-01-01
使用OpenFeign實(shí)現(xiàn)服務(wù)調(diào)用的方法詳解
OpenFeign是運(yùn)行在客戶端的聲明式服務(wù)調(diào)用的框架,通過(guò)聲明接口的方式來(lái)達(dá)到對(duì)服務(wù)的調(diào)用,本文就來(lái)和大家講講如何使用OpenFeign實(shí)現(xiàn)服務(wù)調(diào)用吧2023-06-06
Java Swing組件編程之JTable表格用法實(shí)例詳解
這篇文章主要介紹了Java Swing組件編程之JTable表格用法,結(jié)合實(shí)例形式詳細(xì)分析了Swing組件中JTable表格的常見(jiàn)定義與使用方法,需要的朋友可以參考下2017-11-11
詳解Java?List中五種常見(jiàn)實(shí)現(xiàn)類的使用
Java中提供了非常多的使用的List實(shí)現(xiàn)類,本文將重點(diǎn)介紹一下常見(jiàn)的五種實(shí)現(xiàn)類以及他們的應(yīng)用場(chǎng)景,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-10-10

