http 上传文件
@RequestMapping(method=RequestMethod.POST,value = "/upload")
public ModelAndView processImageUpload(@RequestParam(value="groupname",required=false) String group,
@RequestParam(value="remotefilename",required=false) String remotefilename,
@RequestParam(value="extname",required=true) String extname,
@RequestParam("file") MultipartFile file ,@RequestParam(value="format",required=false) String format // 关键就是这句话起了作用
){
Response<FastDFSFile> response = new Response<FastDFSFile>();
ReturnResult<FastDFSFile> returnResult = new ReturnResult<FastDFSFile>();
ResponseHeader responseHeader = new ResponseHeader();
boolean appendFlag = false;
String[] results = null;
try {
if (!file.isEmpty()) {
if(group != null && !group.equals("") && remotefilename != null && !remotefilename.equals("")){
results = new String[2];
results[0] = group;
results[1] = remotefilename;
appendFlag = true;
}else
appendFlag = false;
byte[] file_buff = file.getBytes(); String[] fDinfo = FastDFS.getServer().upload(appendFlag, results, file_buff, extname);
if(fDinfo.length == 2){
List<FastDFSFile> fileList = new ArrayList<FastDFSFile>();
FastDFSFile info = new FastDFSFile();
info.setGroupname(fDinfo[0]);
info.setRemotefilename(fDinfo[1]);
fileList.add(info);
responseHeader.setStatus(0);
returnResult.setNumFound(1);
returnResult.setStart(1);
returnResult.setFilelist(fileList);
}else if(fDinfo.length == 1){
throw new UFEException(fDinfo[0]);
}else{
throw new UFEException("no return fastDFS!");
}
}else{
RError er = new RError();
er.setInfo("No file!");
er.setType(1);
responseHeader.setError(er);
responseHeader.setStatus(1);
}
} catch (Exception e1) {
RError er = new RError();
if(e1.getCause() == null)
er.setInfo(e1.getMessage());
else
er.setInfo(e1.getCause().getMessage());
er.setType(1);
responseHeader.setStatus(1);
responseHeader.setError(er);
}
response.setResult(returnResult);
response.setResponseHeader(responseHeader);
if(format != null && format.equals("json"))
return new ModelAndView(TypeDef.JSON_VIEW_NAME, "object", response);
else
return new ModelAndView(TypeDef.XML_VIEW_NAME, "object", response);
}
http 上传文件的更多相关文章
- IE8/9 JQuery.Ajax 上传文件无效
IE8/9 JQuery.Ajax 上传文件有两个限制: 使用 JQuery.Ajax 无法上传文件(因为无法使用 FormData,FormData 是 HTML5 的一个特性,IE8/9 不支持) ...
- 三种上传文件不刷新页面的方法讨论:iframe/FormData/FileReader
发请求有两种方式,一种是用ajax,另一种是用form提交,默认的form提交如果不做处理的话,会使页面重定向.以一个简单的demo做说明: html如下所示,请求的路径action为"up ...
- asp.net mvc 上传文件
转至:http://www.cnblogs.com/fonour/p/ajaxFileUpload.html 0.下载 http://files.cnblogs.com/files/fonour/aj ...
- app端上传文件至服务器后台,web端上传文件存储到服务器
1.android前端发送服务器请求 在spring-mvc.xml 将过滤屏蔽(如果不屏蔽 ,文件流为空) <!-- <bean id="multipartResolver&q ...
- .net FTP上传文件
FTP上传文件代码实现: private void UploadFileByWebClient() { WebClient webClient = new WebClient(); webClient ...
- 通过cmd完成FTP上传文件操作
一直使用 FileZilla 这个工具进行相关的 FTP 操作,而在某一次版本升级之后,发现不太好用了,连接老是掉,再后来完全连接不上去. 改用了一段时间的 Web 版的 FTP 工具,后来那个页面也 ...
- 前端之web上传文件的方式
前端之web上传文件的方式 本节内容 web上传文件方式介绍 form上传文件 原生js实现ajax上传文件 jquery实现ajax上传文件 form+iframe构造请求上传文件 1. web上传 ...
- Django session cookie 上传文件、详解
session 在这里先说session 配置URL from django.conf.urls import patterns, include, url from django.contrib i ...
- 4 django系列之HTML通过form标签来同时提交表单内容与上传文件
preface 我们知道提交表单有2种方式,一种直接通过submit页面刷新方法来提交,另一种通过ajax异步局部刷新的方法提交,上回我们说了通过ajax来提交文件到后台,现在说说通过submit来提 ...
- 1. Django系列之Django与ajax上传文件
html代码如下: <div class="form-group"> <label for="exampleInputFile">附件上 ...
随机推荐
- Java 内存区域和GC机制
目录 Java垃圾回收概况 Java内存区域 Java对象的访问方式 Java内存分配机制 Java GC机制 垃圾收集器 Java垃圾回收概况 Java GC(Garbage Collection, ...
- JS添加MD5,JS提示框
http://pan.baidu.com/s/1kTmSp9t
- SpringBoot Jms
https://dzone.com/articles/spring-boot-example-of-spring-integration-and-acti
- Linux 标准目录结构
初学Linux,首先需要弄清Linux 标准目录结构 / root --- 启动Linux时使用的一些核心文件.如操作系统内核.引导程序Grub等. home --- 存储普通用户的个人文件 ftp ...
- Delphi中DLL的创建和使用
参考:http://blog.csdn.net/ninetowns2008/article/details/6311663 结合这篇博客:http://www.cnblogs.com/xumenger ...
- Delphi函数指针
参考:http://blog.chinaunix.net/uid-91034-id-2009700.html http://blog.csdn.net/procedure1984/article/de ...
- Linux Shell 高级编程技巧4----几个常用的shell脚本例子
4.几个常用的shell脚本例子 4.0.在写脚本(同样适用在编程的时候),最好写好完善的注释 4.1.kill_processes.sh(一个杀死进程的脚本) #!/bin/bash c ...
- scrollTop和scrollLeft的兼容解决万全方法
1.各浏览器下 scrollTop的差异 IE6/7/8: 对于没有doctype声明的页面里可以使用 document.body.scrollTop 来获取 scrollTop高度 : 对于有do ...
- Cube Processing Options
在 Microsoft SQL Server Analysis Services 中处理对象时,您可以选择处理选项以控制每个对象的处理类型. 处理类型因对象而异,并基于自上次处理对象后对象所发生的更 ...
- ubuntu wubi非在线快速安装
最近ubuntu更新了,就想把它重新装回来试一下,但是由于种种原因划分磁盘不太方便,很自然就想到了wubi,这个不仅仅安全性高,而且比直接装系统快多了,而且方便.但是在线安装实在是太慢了,所以就找到了 ...