zoukankan      html  css  js  c++  java
  • List<MultipartFile>序列化成String和将序列化成String的文件反序列化

    场景来源:无法给Dubbo接口传参数,List<MultipartFile> files不支持。

    解决方法:Base64将文件序列化为String。Dubbo再解析成List。

    List<MultipartFile>转成String:

    public String uploadFj(List<MultipartFile> files){
            try {
                
                if(files==null||files.size()==0){
                    throw new RuntimeException("附件为空");
                }
                List<Map<String,Object>>list =new ArrayList<Map<String,Object>>();
                for(MultipartFile f:files){
                    Map<String,Object>map=new HashMap<String,Object>();
                    String filename = f.getOriginalFilename();
                    byte[] bytes = f.getBytes();
                    map.put("fileName", filename);
                    map.put("fileByte", Base64.encodeBase64String(bytes));
                    list.add(list.size(),map);
                }
                String jsonfiles = JSONObject.toJSONString(list);
                
                return jsonfiles;
            } catch (Exception e) {
                throw new RuntimeException(e.getMessage());
            }
        }

    从序列化后的String提取数据:

    public void formatUpload01(String fid, String userid, String username, String businesstag, String fileobj){
             try {
                List<Map> attachList=JSONObject.parseArray(fileobj,Map.class);
                if(attachList!=null && attachList.size()>0){
                    String fileid = null;
                    for(Map m:attachList){
                        byte[] fileByte=Base64.decodeBase64(m.get("fileByte")==null?"":m.get("fileByte").toString());
                        String fileName=m.get("fileName").toString();
                    }
                }
            } catch (Exception e) {
                throw new RuntimeException(e.getMessage());
            }
         }
  • 相关阅读:
    poj3181(Dollar Dayz)
    poj3666(Making the Grade)
    poj2392(Space Elevator)
    hdu5288(OO’s Sequence)
    hdu5289(Assignment)
    快学scala
    Spark Checkpointing
    Spark Performance Tuning (性能调优)
    Spark Memory Tuning (内存调优)
    Sparkstreaming and Kafka
  • 原文地址:https://www.cnblogs.com/whirlwind/p/12179860.html
Copyright © 2011-2022 走看看