SpringMVC接收和響應(yīng)json數(shù)據(jù)的方法有哪些

SpringMVC接收和響應(yīng)json數(shù)據(jù)的方法有哪些?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

公司主營業(yè)務(wù):成都做網(wǎng)站、成都網(wǎng)站建設(shè)、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)建站是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)建站推出饒平免費做網(wǎng)站回饋大家。

前后端的數(shù)據(jù)交互,除了通過form表單進(jìn)行提交外,也可以通過ajax向后端傳遞和接收json格式數(shù)據(jù)(這種方式可以實現(xiàn)請求數(shù)據(jù)和頁面分離)。本文將總結(jié)一下在Spring MVC中接收和響應(yīng)json數(shù)據(jù)的幾種方式。

準(zhǔn)備步驟:
1.導(dǎo)入json相關(guān)框架的依賴(比如jackson)。
2.spring mvc的controller方法正常寫,如果需要響應(yīng)json,增加@responsebody注解。
3.在接受json對應(yīng)的輸入?yún)?shù)前,加上@RequestBody注解。
服務(wù)端接收json數(shù)據(jù)還原為java對象,稱為反序列化,反之,將java對象作為響應(yīng)轉(zhuǎn)換為json數(shù)據(jù)發(fā)回給客戶端,稱為序列化。

注意:因為要使用ajax,所有一定要引入jQuery,切記!

jackson maven依賴:

        <!-- jackson依賴 -->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <version>2.7.0</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.7.0</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.7.0</version>
        </dependency>

一、以實體類接收

背景:當(dāng)ajax傳遞的參數(shù)較多時,采用參數(shù)名匹配的方法不太方便。如果后臺有對應(yīng)的實體類,這時可以選擇在客戶端將數(shù)據(jù)封裝為json格式傳遞給后臺,后臺用對應(yīng)的實體類進(jìn)行接收。

客戶端:

<button onclick="clickMe()">點我</button>
<script>
    function clickMe() {
        $.ajax({
            type : 'POST',
            url : "acceptJsonByEntity",
            contentType : "application/json;charset=utf-8",
            // 如果想以json格式把數(shù)據(jù)提交到后臺的話,JSON.stringify()必須有,否則只會當(dāng)做表單提交
            data : JSON.stringify({
                "bookId" : 1,
                "author" : "Jack"
            }),
            // 期待返回的數(shù)據(jù)類型
            dataType : "json",
            success : function(data) {
                var bookId = data.bookId;
                var author = data.author;
                alert("success:" + bookId+','+author);
            },
            error : function(data) {
                alert("error" + data);
            }
        });
</script>
@responseBody注解是將controller的方法返回的對象通過適當(dāng)?shù)霓D(zhuǎn)換器轉(zhuǎn)換為指定的格式之后,寫入到response對象的body區(qū),通常用來返回JSON數(shù)據(jù)或者是XML。

@RequestBody注解常用來處理content-type不是默認(rèn)的application/x-www-form-urlcoded編碼的內(nèi)容。一般情況下來說常用其來處理application/json類型。

Controller:

@Controller
public class PassJsonParam {
    @RequestMapping(value="acceptJsonByEntity",method = RequestMethod.POST)
    @ResponseBody
    public Book acceptJsonByEntity(@RequestBody Book book, HttpServletRequest request){
        System.out.println("當(dāng)前http請求方式為:"+request.getMethod());
        System.out.println("bookId="+book.getBookId()+", author="+book.getAuthor());
        return book;
    }
}

控制臺輸出:當(dāng)前http請求方式為:POST    bookId=1, author=Jack

客戶端(彈窗):success:1,Jack


如果Controller中的所有方法都需要返回json格式數(shù)據(jù),可以使用@RestController注解。

@RestController = @Controller + @ResponseBody

Controller(上面的Controller可以用下面的替換):

@RestController
public class PassJsonParam {
    @RequestMapping(value="acceptJsonByEntity",method = RequestMethod.POST)
    public Book acceptJsonByEntity(@RequestBody Book book, HttpServletRequest request){
        System.out.println("當(dāng)前http請求方式為:"+request.getMethod());
        System.out.println("bookId="+book.getBookId()+", author="+book.getAuthor());
        return book;
    }
}

注意:使用了@RestController注解后,Controller的方法無法再返回jsp頁面或者h(yuǎn)tml,配置的視圖解析器也不會起作用。

二、以map方式接收

背景:前臺向后臺發(fā)送ajax請求并且攜帶很多參數(shù),而后臺并沒有對應(yīng)的實體類進(jìn)行接收又該如何處理呢?最常見的就是表單,這里可以考慮使用map來解決。因為map的數(shù)據(jù)結(jié)構(gòu)為key-value形式,所以我們可以遍歷搜索框表單,將表單的name作為map的key,表單的value作為map的value。

客戶端:

<form id="bookForm">
    <input type="text" name="bookName" id="bookName">
    <input type="text" name="author" id="author" >
    <button onclick="submitForm(event)">提交</button>
</form>

<script>
    function submitForm(event) {
        //阻止form默認(rèn)事件
        event.preventDefault();
        //得到搜索框數(shù)據(jù)
        var map = new Map();
        $("#bookForm input").each(function () {
            var value = $(this).val();      //input 值
            var name = $(this).attr('name');
            map.set(name,value);
        })

        //Map轉(zhuǎn)為Json的方法
        var obj= Object.create(null);
        for (var [k,v] of map) {
            obj[k] = v;
        }

        $.ajax({
            type: 'POST',
            contentType:'application/json',
            url: "acceptJsonByMap",
            data: JSON.stringify(obj),
            dataType: 'json',
            success: function (data) {
                var bookName = data.bookName;
                var author = data.author;
                alert("bookName ="+bookName+"; author="+author);
            },
            error: function (data) {
                alert("失敗啦");
            }
        });
    }
</script>

Controller:

    @RequestMapping(value="acceptJsonByMap")
    @ResponseBody
    public Map<String,Object> acceptJsonByMap(@RequestBody Map<String,Object> paramsMap, HttpServletRequest request){
        System.out.println("當(dāng)前http請求方式為:"+request.getMethod());
        System.out.println(paramsMap);
        return paramsMap;
    }

控制臺輸出:當(dāng)前http請求方式為:POST    {bookName=Love, author=Frank}

客戶端(彈窗):bookName =Love; author=Frank

三、以list方式接收(以json數(shù)組形式傳遞)

客戶端:

<button onclick="clickHere()">clickHere</button>
<script>
    function clickHere() {
        var params1 = {
            "bookId":"123",
            "author":"Rose"
        };
        var params2 = {
            "bookId":"321",
            "author":"Jack"
        };
        var list = [];
        list.push(params1);
        list.push(params2);

        $.ajax({
            type: 'POST',
            contentType:'application/json',
            url: "acceptJsonByList",
            data: JSON.stringify(list),
            dataType: 'json',
            success: function (data) {
                for (let i = 0; i < data.length; i++) {
                    var bookId = data[i].bookId;
                    var author = data[i].author;
                    alert("bookId ="+bookId+"; author="+author);
                }
            },
            error: function (data) {
                alert("失敗啦");
            }
        });
    }
</script>

注意:傳遞到后端時,list應(yīng)為[ { key1 : value1}{ key2 : value2} ]的json格式數(shù)據(jù),否則可能會出現(xiàn)Json parse error錯誤。

Controller:

    @RequestMapping(value="acceptJsonByList")
    @ResponseBody
    public List<Book> acceptJsonByList(@RequestBody List<Book> book, HttpServletRequest request){
        System.out.println("當(dāng)前http請求方式為:"+request.getMethod());
        System.out.println(book);
        return book;
    }

注意:這里需要Book實體類進(jìn)行接收。

控制臺輸出:當(dāng)前http請求方式為:POST    [entity.Book@1138a75c, entity.Book@22d1cbcf]

客戶端(彈窗):bookId =123; author=Rose    bookId =321; author=Jack

關(guān)于SpringMVC接收和響應(yīng)json數(shù)據(jù)的方法有哪些問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

分享文章:SpringMVC接收和響應(yīng)json數(shù)據(jù)的方法有哪些
本文URL:http://bm7419.com/article26/gihcjg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、App設(shè)計網(wǎng)站維護(hù)、全網(wǎng)營銷推廣搜索引擎優(yōu)化、企業(yè)網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)