先上正确的示例:

主要是设置我们的request的content-type为multipart/form-data

NSDictionary *param = @{@"assignee"     :self.userId,
@"projectName" :itemName.text,
@"proceedingName":Name.text,
@"content" :content.text,
@"urgency" :string
};
BaseNetwork *net = [BaseNetwork new];
[net.httpSessionManager.requestSerializer setValue:@"multipart/form-data" forHTTPHeaderField:@"Content-Type"];
[net uploadImageRequestURL:[NSString stringWithFormat:@"%@act/proceeding/start", GW_Domain] imageArray:self.imageArray parameters:param progress:^(float progress) {

其次是,将我们获取的imageArray(文件集合)按照web端(后台)的key约定,组装。【我们Java 后台的文件集合声明的key名称是files】

------至此,ios这边的代码就结束了。

Java后台:

controller层

  /**
* 发起申请(app)
*
* @param proceeding
* @return
*/
@ResponseBody
@RequestMapping("/start")
// @RequiresPermissions("act:proceeding:apply")
public R start(Proceeding proceeding) {
try {
// 启动事项审批工作流程
proceedingService.appStartProcess(proceeding, getUser());
return R.ok();
} catch (BDException e) {
LOGGER.error("app端发起事项审批流程异常", e);
return R.error(e.getMessage());
} catch (Exception e) {
LOGGER.error("app端发起事项审批流程异常", e);
return R.error();
}
}
Proceeding 载体bean
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.springframework.web.multipart.MultipartFile;
import com.shengshi.common.domain.UploadFileDO;
import com.shengshi.common.exception.FileException;
import com.shengshi.common.utils.Base64Utils; public class Proceeding implements Serializable { private static final long serialVersionUID = 1L; /**
* 主键UUID
*/
private String id; /**
* 事项审批申请人
*/
private Long userId; /**
* 项目名称
*/
private String projectName; /**
* 事项名称
*/
private String proceedingName; /**
* 事项内容
*/
private String content; /**
* 缓急程度 0:常规 1:紧急 2:特级
*/
private String urgency; /**
* 创建时间
*/
private Date createTime; /**
* 事项审批状态 0:录入 1:审核中 2:审核通过 3:审核不通过
*/
private String status; /**
* 事项审批流程实例ID
*/
private String procInstId; /**
* 任务指定处理人
*/
private String assignee; /**
* 任务发起时间
*/
private Date applyTime; /**
* 上传文件列表,之所以没有规范为multipartfile是在get方法做了另外封装【要兼容移动端和app】
*/
private List<Object> files; /**
* 关联文件,多个用逗号分隔
*/
private String delIds; /**
* 上传文件记录列表
*/
private List<UploadFileDO> uploadFileList; public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} public Long getUserId() {
return userId;
} public void setUserId(Long userId) {
this.userId = userId;
} public String getProjectName() {
return projectName;
} public void setProjectName(String projectName) {
this.projectName = projectName;
} public String getProceedingName() {
return proceedingName;
} public void setProceedingName(String proceedingName) {
this.proceedingName = proceedingName;
} public String getContent() {
return content;
} public void setContent(String content) {
this.content = content;
} public String getUrgency() {
return urgency;
} public void setUrgency(String urgency) {
this.urgency = urgency;
} public Date getCreateTime() {
return createTime;
} public void setCreateTime(Date createTime) {
this.createTime = createTime;
} public String getStatus() {
return status;
} public void setStatus(String status) {
this.status = status;
} public String getProcInstId() {
return procInstId;
} public void setProcInstId(String procInstId) {
this.procInstId = procInstId;
} public String getAssignee() {
return assignee;
} public void setAssignee(String assignee) {
this.assignee = assignee;
} public Date getApplyTime() {
return applyTime;
} public void setApplyTime(Date applyTime) {
this.applyTime = applyTime;
} public List<Object> getFiles() {
return files;
} public void setFiles(List<Object> files) {
this.files = files;
} //之所以封装这个方法,是因为我们需要兼容app(直接form表单提交,文件类型)和h5移动端(将文件用base64 encode一下,以字符串的形式传输)的文件上传
public List<MultipartFile> getFileList() throws FileException {
List<MultipartFile> list = new ArrayList<MultipartFile>();
if (files == null) {
return list;
}
for (Object obj : files) {
if (obj instanceof MultipartFile) {
list.add((MultipartFile) obj);
} else {// 移动app的from提交,文件为base64字符串
// 截取文件字符串 获取文件的类型和内容 base64文件的形式
// “data:image/jpeg;base64,kjkjfkj4k5j43kj34j34kj534k5j43j34kj5k34j5534kj5534j4”
// 这里再说明一下,如果将来对接android图片上传也采取base64方式的时候,
// 有可能解析文件不全,因为Java后台默认会把“+”(加号)替换成“ ”空格,接收的时候先把空格全部替换成“+”
String base64Img = obj.toString();
list.add(Base64Utils.base64ConvertFile(base64Img));
}
}
return list;
} public String getDelIds() {
return delIds;
} public void setDelIds(String delIds) {
this.delIds = delIds;
} public List<UploadFileDO> getUploadFileList() {
return uploadFileList;
} public void setUploadFileList(List<UploadFileDO> uploadFileList) {
this.uploadFileList = uploadFileList;
} }

------正确示例到此结束

我们出现的问题就是,ios端不小心将文件参数多封装了一层,如下:

NSDictionary *param = @{@"assignee"     :self.userId,
@"projectName" :itemName.text,
@"proceedingName":Name.text,
@"content" :content.text,
@"urgency" :string,
                 @"files" :data
};
BaseNetwork *net = [BaseNetwork new];
[net.httpSessionManager.requestSerializer setValue:@"multipart/form-data" forHTTPHeaderField:@"Content-Type"];
[net uploadImageRequestURL:[NSString stringWithFormat:@"%@act/proceeding/start", GW_Domain] imageArray:self.imageArray parameters:param progress:^(float progress) {

就是这个多给的参数,【files】. 后台得到的等于是key:files value:formdata。   本来要的是文件的格式,因为疏忽,导致后台一直按照字符串解析,匹配不成文件类型。记录一下。【本文图一已经对imageArray便利处理时加了相应的key,所以无需在form表单再去嵌套】

 

IOS 多文件上传 Java web端(后台) 使用List<MultipartFile> 接收出现的问题的更多相关文章

  1. 文件上传(java web)

    文件上传: 对表单的要求: * method="post" * enctype="multipart/form-data" * 表单中需要添加文件表单项:< ...

  2. 前后端分离跨服务器文件上传-Java SpringMVC版

    近来工作上不上特别忙,加上对后台java了解一点,所以就抽时间,写了一个java版本的前后端分离的跨服务器文件上传功能,包括前后端代码. 一.Tomcat服务器部分 1.Tomcat服务器 单独复制一 ...

  3. 【iOS】文件上传小记

    iOS由该系统提供API可以实现可以实现文件的上传和下载,有两种方法来. NSURLConnection与NSURLSession. 当中NSURLConnection是使用非常久的的一种方式.NSU ...

  4. jquery-ajax实现文件上传异常处理web.multipart.MultipartException

    异常如下: org.springframework.web.multipart.MultipartException: The current request is not a multipart r ...

  5. Selenium的文件上传JAVA脚本

    在写文件上传脚本的时候,遇到了很多问题,包括元素定位,以及上传操作,现在总结下来以下几点: 1. 上传的控件定位要准确,必要时要进行等待 WebElement adFileUpload = drive ...

  6. springboot文件上传 流的方式 后台计算上传进度

    //代码 public static void main(String[] args) throws Exception { String path = "f:/svn/t_dictiona ...

  7. aliyun oss 文件上传 java.net.SocketTimeoutException Read timed out 问题分析及解决

    upload ClientException Read timed out com.aliyun.openservices.ClientException: Read timed out        ...

  8. 记录: 百度webuploader 分片文件上传java服务器端(spring mvc)示例的优化

    最近项目上用到文件分片上传,于是找到了百度的一个开源前端控件webuploader. 于是尝试使用. 下载下来后,它提供的服务器端示例代码是php版的,那么Java版的呢? 其实,上传文件都是按照rf ...

  9. ios 多文件上传

    /** *  上传多个文件 * *  @param url      请求接口地址 *  @param filedata 文件名称和数据(key:value) *  @param btnName  上 ...

随机推荐

  1. 脚手架vue-cli系列四:vue-cli工程webpack的基本用法

    webpack的打包依赖于它的一个重要配置文件webpack.config.js,在这个配置文件中就可以指定所有在源代码编译过程中的工作了,就一个配置就可以与冗长的Gruntfile或者Gulpfil ...

  2. Docker总结(脑图图片)

  3. 微服务架构集大成者—Spring Cloud (转载)

    软件是有生命的,你做出来的架构决定了这个软件它这一生是坎坷还是幸福. 本文不是讲解如何使用Spring Cloud的教程,而是探讨Spring Cloud是什么,以及它诞生的背景和意义. 1 背景 2 ...

  4. Java SE 9(JDK9)环境安装及交互式编程环境Jshell使用示例

    目的 安装JDK 9, 练习Jshell工具的使用, 体验Java的交互式编程环境. 什么是Jshell 其实就是一个命令行工具,安装完JDK9后,可以在bin目录下找到该工具,与Python的解释器 ...

  5. react 字符串强转为html标签

    react中,富文本编辑 从数据库取出来 是带标签的 字符串,需要强转为 节点 <div dangerouslySetInnerHTML={{ __html: this.state.obj.ht ...

  6. 从零开始学 Web 之 移动Web(七)Bootstrap

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  7. zmq Poller

    1.注册socket到poller中 poller = zmq.Poller() poller.register(frontend, zmq.POLLIN) # receive worker mess ...

  8. angular学习笔记-关于ng-class的那些事儿

    在angular中为我们提供了3种方案处理class: 第一种:通过数据的双向绑定(一般是不推荐的) 注意:当它的值为一个字符串时,它就会把用空格分开的字符串加到class中(不推荐,与常用class ...

  9. Python 浅谈编程规范和软件开发目录规范的重要性

    最近参加了一个比赛,然后看到队友编程的代码,我觉得真的是觉得注释和命名规范的重要性了,因为几乎每个字符都要咨询他,用老师的话来说,这就是命名不规范的后续反应.所以此时的我意识到写一篇关于注释程序的重要 ...

  10. Maven教程(3)--Maven导入工程常见问题(编码、MavenArchiver、Lifecycle Mapping、maven install 没有反应)

    常见错误: 常见错误一:These projects must be migrated to correctly function in this version of MyEclipse 需要修改编 ...