91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用@RequestBody傳遞多個不同對象方式

發布時間:2021-10-22 13:35:45 來源:億速云 閱讀:909 作者:iii 欄目:開發技術

本篇內容主要講解“怎么使用@RequestBody傳遞多個不同對象方式”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么使用@RequestBody傳遞多個不同對象方式”吧!

目錄
  • @RequestBody傳遞多個不同對象

    • 解決方案1

    • 解決方案2

  • 使用多個@RequestBody接收參數

    • 原因

    • 解決辦法:兩個類,直接copy即可

@RequestBody傳遞多個不同對象

如果使用spring mvc同客戶端通信,完全使用json數據格式,需要增加RequestBody注解,函數參數為自定義類

@Controller
public class TestController{
  @RequestMapping("\test")
  @ResponseBody
  public RetureResult test(@RequestBody User user){
    return new ReturnResult();
  }  
}

這樣的話,可以將接收到的json格式的數據轉換為指定的數據對象user。比如{name:"test"},name為User類的屬性域。通過ResponseBody注解,可以返回json格式的數據。

有時接收json格式數據時,我們可能需要將其轉換為多個對象。

以下方式是錯誤的。原因是request的content-body是以流的形式進行讀取的,讀取完一次后,便無法再次讀取了。

@Controller
public class TestController{
  @RequestMapping("\test")
  @ResponseBody
  public RetureResult test(@RequestBody User user,@RequestBody Address address){
    return new ReturnResult();
  }  
}

解決方案1

增加一個包裝類,將所需要類寫入,增加get,set方法

@Controller
public class TestController{
  @RequestMapping("\test")
  @ResponseBody
  public RetureResult test(@RequestBody Param param){
    User user=param.getUser();
    Address address=param.getAddress();
    return new ReturnResult();
  }  
}
class Param{
 
    private User user;
    private Address address;  
 
    public User getUser() {
        return user;
    }
 
    public void setUser(User user) {
        this.user = user;
    }
 
    public Address getAddress() {
        return address;
    }
 
    public void setAddress(Address address) {
        this.address = address;
    }
}

此時傳輸的json數據格式變為{user:{name:"test"},address:{location:"新華路"}}。

由于只是在TestController中增加一個包裝類,不會影響其他的類以及已經定義好的model類,因此可以非常方便的達到接收多個對象參數的目的。

解決方案2

將接收參數定義為Map<String, Object>,然后使用map轉object工具,轉換成需要的對象。

此時,即使自定義的Param類中的屬性即使比json數據中的屬性少了,也沒關系。

其中JSONUtils為自定義的工具類,可使用常見的fastjson等工具包包裝實現。

@Controller
public class TestController{
  @RequestMapping("\test")
  @ResponseBody
  public Object test(@RequestBody Map<String, Object> models){
   User user=JsonXMLUtils.map2object((Map<String, Object>)models.get("user"),User.class); 
   Address address=JsonXMLUtils.map2object((Map<String, Object>)models.get("address"),Address.class); 
   return models; 
 }
}
import com.alibaba.fastjson.JSON;
 
public class JsonXMLUtils {
    public static String obj2json(Object obj) throws Exception {
        return JSON.toJSONString(obj);
    }
 
    public static <T> T json2obj(String jsonStr, Class<T> clazz) throws Exception {
        return JSON.parseObject(jsonStr, clazz);
    }
 
    public static <T> Map<String, Object> json2map(String jsonStr)     throws Exception {
            return JSON.parseObject(jsonStr, Map.class);
    }
  
    public static <T> T map2obj(Map<?, ?> map, Class<T> clazz) throws Exception {
        return JSON.parseObject(JSON.toJSONString(map), clazz);
    }
}

使用多個@RequestBody接收參數

原因

常規情況下,因為request的body只能讀取一次,@RequestBody也只能解析一次,這就導致解析第二個的@RequestBody的時候stream已經關閉了,無法再次讀取。

話不多說,上貨:

解決辦法:兩個類,直接copy即可

import javax.servlet.ReadListener;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import java.io.*; 
public class BodyReaderRequestWrapper extends HttpServletRequestWrapper {
    private final String body;
 
    /**
     *
     * @param request
     */
    public BodyReaderRequestWrapper(HttpServletRequest request) throws IOException{
        super(request);
        StringBuilder sb = new StringBuilder();
        InputStream ins = request.getInputStream();
        BufferedReader isr = null;
        try{
            if(ins != null){
                isr = new BufferedReader(new InputStreamReader(ins));
                char[] charBuffer = new char[128];
                int readCount = 0;
                while((readCount = isr.read(charBuffer)) != -1){
                    sb.append(charBuffer,0,readCount);
                }
            }else{
                sb.append("");
            }
        }catch (IOException e){
            throw e;
        }finally {
            if(isr != null) {
                isr.close();
            }
        }
 
        sb.toString();
        body = sb.toString();
    }
 
    @Override
    public BufferedReader getReader() throws IOException {
        return new BufferedReader(new InputStreamReader(this.getInputStream()));
    }
 
    @Override
    public ServletInputStream getInputStream() throws IOException {
        final ByteArrayInputStream byteArrayIns = new ByteArrayInputStream(body.getBytes());
        ServletInputStream servletIns = new ServletInputStream() {
            @Override
            public boolean isFinished() {
                return false;
            }
 
            @Override
            public boolean isReady() {
                return false;
            }
 
            @Override
            public void setReadListener(ReadListener readListener) {
 
            }
 
            @Override
            public int read() throws IOException {
                return byteArrayIns.read();
            }
        };
        return  servletIns;
    }
}
import org.springframework.stereotype.Component; 
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
 
@Component
@WebFilter(filterName = "crownFilter", urlPatterns = "/*")
public class BodyReaderRequestFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException { 
    }
 
    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest)req;
        HttpServletResponse response = (HttpServletResponse)res;
        BodyReaderRequestWrapper requestWrapper  = new BodyReaderRequestWrapper(request);
        if(requestWrapper == null){
            filterChain.doFilter(request,response);
        }else {
            filterChain.doFilter(requestWrapper,response);
        }
    }
 
    @Override
    public void destroy() { 
    }
}

使用:自行測試。

到此,相信大家對“怎么使用@RequestBody傳遞多個不同對象方式”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

治县。| 枣阳市| 深圳市| 唐海县| 库伦旗| 吉林省| 台东市| 宁阳县| 诸暨市| 甘孜| 濮阳市| 左权县| 京山县| 库车县| 霍林郭勒市| 县级市| 普陀区| 仙桃市| 信阳市| 环江| 黄骅市| 冀州市| 大同市| 肃南| 大洼县| 漠河县| 通榆县| 阳高县| 灵台县| 遵义市| 山东省| 左权县| 得荣县| 芮城县| 汕头市| 嘉义市| 南靖县| 开阳县| 咸阳市| 元氏县| 泉州市|