利用H5 FormData 实现表单中多图上传(可带其他如String类型数据)
本篇的具体思路来源于右侧网址:http://blog.csdn.net/qq_19551571/article/details/49977983
本篇代码有所修改,请具体区分。
本篇使用的是 form 提交,ajax 发送请求(但个人感觉把容器换成 div 之类的也是一样的思路,待验证),提交数据类型 FormData 对象。
H5中 form 表单的代码:
<form class="inpform" id="uploadForm" enctype="multipart/form-data">
<!-- 注意enctype必须得填 -->
<div class="f-inp">
<div><i>请输入您的号码:</i>
<input type="text" name="phone" id="phone" >
</div> <input type="file" id="files" name="files" multiple/> <!-- multiple 确保能选择多文件 -->
</div>
</form> <input type="button" value="提交" onclick="add();">
js、ajax代码:
function add(){
var formData = new FormData($("#uploadForm")[0]);//用form 表单直接 构造formData 对象; 就不需要下面的append 方法来为表单进行赋值了。
$.ajax({
async: false, //要求同步 不是不需看你的需求
url : "/uploadImage/save",
type : 'POST',
data : formData,
processData : false, //必须false才会避开jQuery对 formdata 的默认处理
contentType : false, //必须false才会自动加上正确的Content-Type
success : function(result) {
...
},
error : function(result) {
...
}
});
}
java Spring 中的代码:
处理器
@Controller
@RequestMapping("/uploadImage")
public class UploadController{
@RequestMapping("/savecc")
//注意传入的参数
public void saveImageCC (@RequestParam(value = "files", required = true)MultipartFile[] multipartFiles ,String phone, HttpServletRequest request)throws Exception{
...
//调用文件上传处理类
Map<String, Object> result = UploadFilesUtils_cc.uploadCC(multipartFiles, request, 1, "", phone, 1000, 1000, true);
...
}
} utils类:
public class UploadFilesUtils_cc {
public static Map<String,Object> uploadCC(MultipartFile[] multipartFiles,HttpServletRequest request, int type,String module,String folder,int width,
int height ,Boolean createFolder)
throws UnsupportedEncodingException ,IOException , URISyntaxException{
request.setCharacterEncoding("utf-8");
//结果集
Map<String, Object> result = new HashMap<>();
//图片集
Map<String, String> data = new HashMap<>();
String uploadPath = "E:/reporitory/static/uploadImg/"+folder;
File file = new File(uploadPath);
if(!file.exists()){
file.mkdirs();
}
try{
Boolean success = true ;
String message = "文件上传失败";
String fieldNames = "";
String urls = "";
String uuid ; for(MultipartFile multipartFile:multipartFiles){
if(multipartFile != null){
//如果fileitem中封装的上传文件,得到上传的文件名称
//filename格式"c:/static/mod/xxx.png"
String filename = multipartFile.getOriginalFilename();
fieldNames += "|" + multipartFile.getName(); if(StringUtils.isNotBlank(filename)){
// 注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,如:
// c:\a\b\1.txt,而有些只是单纯的文件名,如:1.txt
// 处理获取到的上传文件的文件名的路径部分,只保留文件名部分
filename = filename.substring(filename.lastIndexOf("/") + 1);
// 得到上传文件的扩展名
String fileExtName = filename.substring(filename.lastIndexOf(".")+1);
// 如果需要限制上传的文件类型,那么可以通过文件的扩展名来判断上传的文件类型是否合法
// 此处是图片格式校验
if((type == Constant.FileType.image.key)
&& !UploadFilesUtils_cc.checkIMGType(fileExtName)) {
message = "图片格式不正确,请重新上传";
success = false;
result.put("success", success);
result.put("message", message);
return result;
//break;
} else {
//使用UUID解决文件重名问题
uuid = UUID.randomUUID().toString(); //数据库里面需要保存的图片上传的路径
String url = uuid + "." + fileExtName; //获取item中的上传文件输入流
InputStream in = multipartFile.getInputStream();
//创建文件输出流
FileOutputStream out = new FileOutputStream(uploadPath + "\\" + url);
//创建缓冲区
byte[] buffer = new byte[1024];
//判断输入流中的数据是否已经读完的标识
int len = 0;
//循环将输入流读入缓冲区,(len=in.read(buffer))>0就表示in里面还有数据
while((len = in.read(buffer)) > 0){
//使用FileOutputStream输出流将缓冲区的数据写入到指定的目录(savePath + "\\" + url)当中
out.write(buffer , 0 , len);
}
//关闭输入流
in.close();
//关闭输出流
out.close(); if(StringUtils.isBlank(urls)){
urls = url;
} else {
urls += "|" + url;
}
}
}
//data.put("linked", "..."+folder+"/"+ urls);
//data.put("filename", filename);
}
}
fieldNames = fieldNames.substring(1);
data.put("phone", folder);
data.put("fieldNames", fieldNames);
data.put("linked","..."+folder+"/"+ urls);
result.put("success", true);
result.put("message", "图片上传成功!");
result.put("data",data); return result;
}catch(Exception e){
System.out.println("上传文件出现错误:" + e.getMessage());
return null;
} }
}
利用H5 FormData 实现表单中多图上传(可带其他如String类型数据)的更多相关文章
- 重置表单中的文件上传控件(file input)的方法
方法一: 调用所在 form 表单的 reset 方法,这个方法的缺点是会把整个表单重置,需要存储表单的状态,再回填回去 方法二: 使用jQuery,代码为: $("#id").r ...
- 利用html5的FormData对象实现多图上传
<html> <head> <title>FormData多图上传演示</title> </head> <body> <a ...
- 利用Jquery使用HTML5的FormData属性实现对文件的上传
1.利用Jquery使用HTML5的FormData属性实现对文件的上传 在HTML5以前我们如果需要实现文件上传服务器等功能的时候,有时候我们不得不依赖于FLASH去实现,而在HTML5到来之后,我 ...
- 项目总结21:项目总结21:input实现多图上传(FormData)(上传OSS并保存数据库)
项目总结21:input实现多图上传(FormData)(上传OSS并保存数据库) 备注:本案例,作为Demo,包含少量的项目业务逻辑,input多图上传的逻辑是完整的: 不废话直接上代码 1-前端标 ...
- js formData图片上传(单图上传、多图上传)后台java
单图上传 <div class="imgUp"> <label>头像单图</label> <input type=&quo ...
- 传统表单提交文件上传,以及FormData异步ajax上传文件
传统的文件上传: 只用将form表单的entype修改成multipart/form-data,然后就可以进行文件上传,这种方式常用并且简单. 以下是另一种方式FormData,有时候我们需要ajax ...
- springBoot+ vue+ Element-ui实现合并多图上传(一次请求多张图片)
这次上传使用的是Elemet-ui的uoload上传组件,组件预留的钩子回调还是比较充足的. 1: 实现多图上传主要用到以下两个属性: 下面讲一下属性使用: <el-upload :actio ...
- 怎么样通过php使用html5实现多文件上传?(php多图上传)
<!DOCTYPE html><html lang="zh-cn"> <head> <meta charset="utf-8&q ...
- thinkphp3.2.2有预览的多图上传
thinkphp3.2.2有预览的多图上传 整体思路 1 封装文件上传和图片上传的类文件 2 视图中添加相关JS和表单提交 3 控制器中添加上传文件的相关代码 一 2个class 文件 请上传到/Th ...
随机推荐
- IDEA+'mvn' 不是内部或外部命令
问题描述: 提示'mvn' 不是内部或外部命令,也不是可运行的程序或批处理文件. 或者提示 The JAVA_HOME environment variable is not defined corr ...
- Java多线程(二)——常用的实现多线程的两种方式
一.继承Thread类创建线程类 Java使用Thread类代表线程,所有的线程对象都必须是Thread类或其子类的实例.每个线程的作用是完成一定的任务,实际上就是执行一段程序流即一段顺序执行的代码. ...
- 多个jdk 变更 引起 tomcat插件 启动不了 The JRE could not be found.Edit the server and change the JRE location.
The JRE could not be found.Edit the server and change the JRE location. 在Windows->Preferences-> ...
- 快看Sample代码,速学Swift语言(3)-运算符
运算符是用来检查,更改或组合值的特殊符号或短语.Swift提供的很多常规的运算符,如+.-.*./.%.=.==等,以及逻辑运算的&&.||等等,基本上不需要重复介绍,我们在这里只需要 ...
- 吉特日化MES-日化生产称料基本步骤
在日化行业称料是一个非常重要的环节,整个生产过程中称料所占据的时间也比较长,特别是遇到对料体精度高,量大的情况下称料都比较困难,汇总一下人工称料的基本过程: (1) 称量任务准备:根据生产工单或者生产 ...
- 【Java并发.3】对象的共享
本章将介绍如何共享和发布对象,从而使他们能够安全地由多个线程同时访问.这两章合在一起就形成了构建线程安全类以及通过 java.util.concurrent 类库来构建开发并发应用程序的重要基础. 3 ...
- flask 更新数据库
在做项目的过程中,我们都遇到过,经常需要修改我们数据库的字段,在flask中,是通过ORM(对象关系映射)来创建数据库的,表--->model class,字段---->属性 在flask ...
- 关于XLL加载项动态加载、卸载的演示及XLL函数自定义类型注册的演示
1.在XLL中,把函数定义成不同的类型,在Excel中的实际效果也不同,具体如下: pxMacroType value ...
- Python文本处理
文本处理 (一)对文本操作的流程: 打开文件,得到文件句柄并赋值给一个变量 通过句柄对文件进行操作 关闭文件 open(file, mode='r', buffering=None, encoding ...
- MongoDB Redis
MongoDB Redis设置用户名密码了吗?看看shodan这款邪恶的搜索引擎吧!~ 早上看新闻的时候看到了个醒目的新闻 开源中国:MongoDB 赎金事件持续发酵,究竟是谁之过?博客园:Mon ...