上传一个单文件,用request.getFile得到文件(下面的功能是上传到阿里云)

   @RequestMapping(value = {"/content"}, method = RequestMethod.POST, headers = "content-type=multipart/form-data")
public String content(ModelMap modelMap,
MultipartHttpServletRequest request,
HttpServletResponse response){
response.setHeader("Access-Control-Allow-Origin", "*");
OSSUpload ossUpload = new OSSUpload("xinmeiti");
Iterator<String> itr = request.getFileNames();
MultipartFile file = request.getFile(itr.next());
Map<String, Object> map = new HashMap<>();
try{
byte[] bytes = org.apache.poi.util.IOUtils.toByteArray(file.getInputStream());
String fileType = getImageType(bytes);
String md5 = StringUtils.md5(String.valueOf(bytes));
String fileName = firstName +"/"+md5 + "."+ fileType;
Map<String, Object> uploadResult = ossUpload.upload(bytes, fileName);
if(!uploadResult.get("status").equals(0)){
modelMap.addAttribute("json", StringUtils.toJson(uploadResult));
}else{
map.put("url", cndName+fileName);
modelMap.addAttribute("json", StringUtils.toJson(map));
}
} catch (IOException e) {
modelMap.addAttribute("json", StringUtils.toJson(new ReturnMap(10004, "上传图片失败")));
e.printStackTrace();
}
return "mis/json";
}

上传多个文件,用request.getFile得到多文件

 @RequestMapping(value = {"multipleFileUpload"}, method =  {RequestMethod.GET, RequestMethod.POST})
public String multipleFileUpload(
ModelMap modelMap,
MultipartHttpServletRequest request,
HttpServletResponse response,
@RequestParam(value = "type") String type,
@RequestParam(value = "jobId") String jobId) throws IOException {
List < MultipartFile > files = request.getFiles("files");
response.setHeader("Access-Control-Allow-Origin", "http://www.gifmiao.com");
Map<String, Object> statusMap = new HashMap<>();
HttpSession session = request.getSession();
session.setAttribute("gifCompressStatus", statusMap);
int compressSize = getCompressSizeByValue(type);
for(MultipartFile file :files){
String filename = file.getOriginalFilename().split(".gif")[0];
Map<String, Object> resultMap = new HashMap<>();
resultMap.put("size" , 0);
resultMap.put("status" , 0);
resultMap.put("url" , "");
statusMap.put(filename, resultMap);
InputStream is = file.getInputStream();
byte[] bytes = IOUtils.toByteArray(is);
CompressWorker worker = new CompressWorker(statusMap, bytes, filename, compressSize, jobId);
worker.start();
}
modelMap.addAttribute("json", StringUtils.toInsensitiveJson(new ReturnMap("线程已启动")));
return "json";
}
在使用MultipartHttpServletRequest类型的时候需要注意,随便什么request都是MultipartHttpServletRequest
在这里举两个可以用MultipartHttpServletRequest的例子。
后端代码:上传一个单文件
 @RequestMapping(value = "/uploadInsight", method = RequestMethod.POST)
public String uploadInsight(ModelMap modelMap,
MultipartHttpServletRequest request,
@RequestParam(value = "category") String category,
@RequestParam(value = "title") String title,
) throws IOException{
Iterator<String> itr = request.getFileNames();
MultipartFile file = request.getFile(itr.next());
Map<String, Object> map = uploadImage(file);
if(!map.get("state").equals("SUCCESS")){
modelMap.addAttribute("json", StringUtils.toJson(new ReturnMap(10004, "上传图片失败")));
return "mis/json";
}
String fengmianImgUrl = (String) map.get("name");
InsightModel insightModel = new InsightModel();
insightModel.setCategory(category);
insightModel.setThumbnail(fengmianImgUrl);
insightModel.setTitle(title);
datastore.save(insightModel);
modelMap.addAttribute("json", StringUtils.toJson((new ReturnMap("OK"))));
return "mis/json";
}
对应的前端代码可以是这样:(原生的js)
function upload(user){            //user是从表单里面接到的数据
var formData = new FormData();
formData.append("title", user.title);
formData.append("file", user.file);
formData.append("category", user.category);
var xhr = new XMLHttpRequest();
xhr.open('POST', "/editor/uploadInsight");
//xhr.withCredentials = true; //这个是关于跨域证书的
xhr.onload = function(){
if(xhr.readyState == 4 && xhr.status == 200){
            console.log("成功")
}
};
xhr.send(formData);
}

对应的前端代码也可以是这样:(jquery方式调用)

   var formData = new FormData();
formData.append("file", file);
formData.append("title", title);
formData.append("category", category); $.ajax({
type : "POST",
url : "/editor/uploadInsight",
data : formData,
processData : false,
contentType : false ,
file:file,
error: function(data) { },
success: function(data) { },
xhr: function() { }
});

												

java,单文件和多文件上传代码范例的更多相关文章

  1. git通过diff文件,合并未上传代码库代码

    今天有段代码需要从别人的机器上同步到本地,但是这段代码还没上库,所以要么将这部分代码打包传过来,或者,用下面的办法. 由于代码修改涉及多个文件,打包搞过来确实比较麻烦,在网上找了下,发现可以用git ...

  2. 使用webstorm上传代码到github

    使用webstorm上传代码到github 字数681 阅读330 评论0 喜欢5 之前使用过webstorm上传代码到github,过了几个月竟然发现自己忘记了,好记性不如烂笔头啊,今天又重新用了一 ...

  3. 初次使用git上传代码到github远程仓库

    https://blog.csdn.net/loner_fang/article/details/80488385 2018年05月28日 21:02:31 蒲公英上的尘埃 阅读数:697 因为最近在 ...

  4. 使用git上传代码到github远程仓库

    一.新建代码库注册好github登录后,首先先在网页上新建代码库. 点击右上角"+"→New repository 进入如下页面:按照要求填写完成后,点击按钮创建代码库创建成功. ...

  5. [html5+java]文件异步读取及上传核心代码

    html5+java 文件异步读取及上传关键代码段 功能: 1.多文件文件拖拽上传,file input 多文件选择 2.html5 File Api 异步FormData,blob上传,图片显示 3 ...

  6. c# 模拟表单提交,post form 上传文件、大数据内容

    表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipart/form-data,而且要设定一个 boundary 参数,这个参数是由应用程序自行产生,它会用来识别每 ...

  7. django 基于form表单上传文件和基于ajax上传文件

    一.基于form表单上传文件 1.html里是有一个input type="file" 和 ‘submit’的标签 2.vies.py def fileupload(request ...

  8. c# 模拟表单提交,post form 上传文件、数据内容

    转自:https://www.cnblogs.com/DoNetCShap/p/10696277.html 表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipar ...

  9. SpringMVC上传压缩文件,解压文件,并检测上传文件中是否有index.html

    SpringMVC上传压缩文件,解压文件,并检测上传文件中是否有index.html 说明: 1.环境:SpringMVC+Spring+Tomcat7+JDK1.7 2.支持 zip和rar格式的压 ...

随机推荐

  1. Linux记录-批量安装zabbix(转载)

    同一文件夹下建立pwd.txt,格式如下: ip username password ip username password #!/bin/bash cat pwd.txt | while read ...

  2. 【物联网】esp8266+LCD

    https://blog.csdn.net/qq_40531588/article/details/89515149

  3. 什么是 https ?这应该是全网把 https 讲的最好的一篇文章了

    https://blog.csdn.net/m0_37907797/article/details/102759257

  4. C#Json数据反序列化为Dictionary并根据关键字获取指定的值

    Json数据: { "dataSet": { "header": { ", "errorInfo": "HTTP请求错误 ...

  5. 解​决​H​T​M​或​H​T​M​L​的​图​标

    HTM和HTML的文件图标不能正常显示,显示为无关联应用程序的白板图标,搞了很久都没能解决,最后综合了几种方法才“搞定”她!出现这种情况的原因可能是安装了某些软件(比如OFFICE.FIREFOX)后 ...

  6. macos的iptables功能是pfctl

    pfctl https://www.kokaruk.com/macos-pf-firewall/ https://blog.csdn.net/yjy1304/article/details/90762 ...

  7. java-socket-demo的实现

    目录 前言 IO通讯模型 IO通讯模型简介 1. 阻塞式同步IO 2. 非阻塞式同步IO 3. 多路复用IO(阻塞+非阻塞) 4. 异步IO Java对IO模型的支持 注意点及实现方案 TCP粘包/拆 ...

  8. 【计算机视觉】基于局部二值相似性模式(LBSP)的运动目标检测算法

    基于局部二值相似性模式(LBSP)的运动目标检测算法 kezunhai@gmail.com http://blog.csdn.net/kezunhai 本文根据论文:Improving backgro ...

  9. 微信公众号使用vue,安卓端点击按钮404,ios访问正常问题

    情景:微信公众号使用vue开发的单页面,在安卓端点击按钮访问显示404,ios访问正常问题,能正常显示. 解决:将微信公众号菜单按钮设置的路径中把WWW去掉后,安卓.ios都能正常访问. 问题路径ww ...

  10. Java创建线程的两种方法

    大多数情况,通过实例化一个Thread对象来创建一个线程.Java定义了两种方式: 实现Runnable 接口: 可以继承Thread类. 下面的两小节依次介绍了每一种方式. 实现Runnable接口 ...