ExtJS+SpringMVC文件上传与下载

时间:2021-08-12 02:00:20

说到文件上传、下载功能,网络上大多介绍的是采用JSP、SpringMVC或者Struts等开源框架的功能,通过配置达到文件上传、下载的目地。可是最近项目要用到文件上传与下载的功能,因为本项目框架采用开源框架SpringMVC、ExtJS、Hibernate写成的,当然借助SpringMVC框架本身的文件上传与下载也可以,但是同样需要和以前一样,编写一些配置文件,所以最近自己搞了一下关于ExtJS、SpringMVC的免配置文件上传与下载的功能研究。

提起文件上传,免不了客户端(提交文件)和服务器端(接收文件)的结合。

首先定义全局相关变量:

  1. /**
  2. * @author:limingzhong
  3. * @desc:定义相关全局静态变量
  4. * @Date:2012-02-28
  5. */
  6. private final static String UPLOAD_SUCCESS = "{success:true,mess:'文件上传成功!'}";
  7. private final static String UPLOAD_FAILURE = "{success:false,mess:'文件上传失败!'}";
  8. private final static String FILE_NO = "{success:false,mess:'文件不存在!'}";
  9. private final static String FILE_YES = "{success:true,mess:'文件存在!'}";
  10. private final static String CONTENT_TYPE = "text/html;charset=gb2312";
  11. private final static String APPLICATION = "application/octet-stream";

客户端:采用ExtJS的formPanel提交功能

  1. var excelUpload = new Ext.form.TextField({
  2. id:'excelUpload',
  3. anchor:'90%',
  4. height:30,
  5. width:350,
  6. name:'file',
  7. inputType:'file',
  8. fieldLabel:'文件选择'
  9. });
  10. var formPanel = new Ext.form.FormPanel({
  11. labelWidth:80,
  12. bodyStyle:'padding:5 5 5 5',
  13. height:515,
  14. width:200,
  15. frame:true,
  16. fileUpload:true,
  17. items:[excelUpload]
  18. });
  19. // 定义按钮
  20. var upLoadFile = new Ext.Toolbar.Button({
  21. text:'上传'
  22. });
  23. // 下载数据功能
  24. var up = function(bt) {
  25. var excelName = Ext.getCmp('excelUpload').getRawValue();// 上传文件名称的路径
  26. if (excelName == ""){
  27. Ext.Msg.show({title:'提示',msg:'请选择文件!',buttons:Ext.Msg.OK,icon:Ext.MessageBox.INFOR});
  28. return;
  29. }else {
  30. var array = new Array();
  31. array = excelName.split("\\");
  32. var length = array.length;
  33. var fileName = "";
  34. var index = 0;
  35. for (index = 0; index < length; index++) {
  36. if (fileName == "") {
  37. fileName = array[index];
  38. } else {
  39. fileName = fileName + "/" + array[index];
  40. }
  41. }
  42. formPanel.getForm().submit({
  43. url:'http://localhost:8080/pro/upload.json',
  44. method:'POST',
  45. waitMsg:'数据上传中, 请稍等...',
  46. success:function(form, action, o) {
  47. Ext.MessageBox.alert("提示信息",action.result.mess);
  48. },
  49. failure : function(form, action) {
  50. Ext.MessageBox.alert("提示信息","请求失败,文件上传失败");
  51. }
  52. });
  53. }
  54. }
  55. // 添加按钮的响应事件
  56. upLoadFile.addListener('click', up, false);
  57. var window = new Ext.Window({
  58. title:'上传文件',
  59. width:500,
  60. height:200,
  61. minWidth:500,
  62. minHeight:200,
  63. layout:'fit',
  64. plain:true,
  65. modal:true,
  66. //closeAction:'hide',
  67. bodyStyle:'padding:5px;',
  68. buttonAlign:'center',
  69. items:formPanel,
  70. buttons:[upLoadFile]
  71. });
  72. window.show();

ExtJS+SpringMVC文件上传与下载

服务器端:根据SpringMVC注解直接调用对应方法,采用流的形式上传文件,这样直接避免配置xml等文件的麻烦。

  1. /**
  2. * @author:limingzhong
  3. * @throws:IOException
  4. * @desc:上传文件
  5. * @params:自带参数,客户端不传入实参
  6. * @Date:2012-02-28
  7. */
  8. @RequestMapping(value = "/upload.json")
  9. public void upLoad(HttpServletRequest request,HttpServletResponse response) throws IOException {
  10. response.setContentType(CONTENT_TYPE);
  11. PrintWriter out = response.getWriter();
  12. if (!ServletFileUpload.isMultipartContent(request)){
  13. out.println(UPLOAD_FAILURE);
  14. }
  15. String name = null;
  16. try {
  17. DiskFileItemFactory factory = new DiskFileItemFactory();
  18. factory.setSizeThreshold(4096);
  19. ServletFileUpload upload = new ServletFileUpload(factory);
  20. upload.setSizeMax(4 * 1024 * 1024);
  21. Iterator<?> iter = upload.parseRequest(request).iterator();
  22. while (iter.hasNext()) {
  23. FileItem item = (FileItem) iter.next();
  24. if (item.isFormField()) {
  25. name = item.getFieldName();
  26. out.println(UPLOAD_FAILURE);
  27. } else {
  28. name = item.getName();
  29. String path = getPath();
  30. if(path==null || path==""){
  31. out.println(UPLOAD_FAILURE);
  32. }else{
  33. item.write(new File(path+name.substring(name.lastIndexOf(File.separator)+1,name.length()))); //保存上传文件
  34. out.println(UPLOAD_SUCCESS);
  35. }
  36. }
  37. }
  38. out.close();
  39. } catch (Exception e) {
  40. out.println(UPLOAD_FAILURE);
  41. out.close();
  42. }
  43. }

至此,文件上传的功能已结束。

下面把下载功能的客户端和服务器端的代码贴出来,以供大家拍砖:

客户端:

  1. window.location.href = 'http://127.0.0.1:8080/pro/down.json?fileName='+encodeURI(encodeURI(fileName));

服务器端:

  1. /**
  2. * @author:limingzhong
  3. * @throws:IOException
  4. * @desc:下载文件
  5. * @params:fileName-文件名称
  6. * @Date:2012-02-28
  7. */
  8. @RequestMapping(value = "/down.json")
  9. public void down(@RequestParam("fileName") String fileName,HttpServletRequest request,HttpServletResponse response) throws IOException {
  10. response.setContentType(APPLICATION);
  11. fileName = URLDecoder.decode(fileName, "utf-8");
  12. String path = getPath()+fileName;
  13. path = path.replace("%20", " ");
  14. File file = new File(path);
  15. // 清空response
  16. response.reset();
  17. // 设置response的Header
  18. response.addHeader("Content-Disposition", "attachment;filename=" + new String(fileName.getBytes("gbk"),"iso8859-1"));
  19. response.addHeader("Content-Length", "" + file.length());
  20. try{
  21. //以流的形式下载文件
  22. InputStream fis = new BufferedInputStream(new FileInputStream(path));
  23. byte[] buffer = new byte[fis.available()];
  24. fis.read(buffer);
  25. fis.close();
  26. OutputStream toClient = new BufferedOutputStream(response.getOutputStream());
  27. toClient.write(buffer);
  28. toClient.flush();
  29. toClient.close();
  30. }catch(Exception e){
  31. e.printStackTrace();
  32. }
  33. }

至此,文件下载的功能已结束。

来自:http://blog.csdn.net/limingzhong198/article/details/7324570

ExtJS+SpringMVC文件上传与下载的更多相关文章

  1. SpringMVC文件上传和下载的实现

    SpringMVC通过MultipartResolver(多部件解析器)对象实现对文件上传的支持. MultipartResolver是一个接口对象,需要通过它的实现类CommonsMultipart ...

  2. SpringMVC文件上传和下载

    上传与下载 1文件上传 1.1加入jar包 文件上传需要依赖的jar包 1.2配置部件解析器 解析二进制流数据. <?xml version="1.0" encoding=& ...

  3. SpringMVC文件上传与下载

    一.关键步骤 ①引入核心JAR文件 SpringMVC实现文件上传,需要再添加两个jar包.一个是文件上传的jar包,一个是其所依赖的IO包.这两个jar包,均在Spring支持库的org.apach ...

  4. springMVC文件上传与下载&lpar;六&rpar;

    1..文件上传 在springmvc.xml中配置文件上传解析器 <!-- 上传图片配置实现类,id必须为这个 --> <bean id="multipartResolve ...

  5. SpringMVC 文件上传及下载

    首先需要导入jar包 创建一个jsp页面 package cn.happy.Controller; import java.io.File; import javax.servlet.http.Htt ...

  6. SpringMVC文件上传下载

    在Spring MVC的基础框架搭建起来后,我们测试了spring mvc中的返回值类型,如果你还没有搭建好springmvc的架构请参考博文->http://www.cnblogs.com/q ...

  7. 使用SpringMVC框架实现文件上传和下载功能

    使用SpringMVC框架实现文件上传和下载功能 (一)单个文件上传 ①配置文件上传解释器 <!—配置文件上传解释器 --> <mvc:annotation-driven>&l ...

  8. springmvc文件上传下载简单实现案例&lpar;ssm框架使用&rpar;

    springmvc文件上传下载实现起来非常简单,此springmvc上传下载案例适合已经搭建好的ssm框架(spring+springmvc+mybatis)使用,ssm框架项目的搭建我相信你们已经搭 ...

  9. springmvc之文件上传、下载

    1.接收到的是图片的流时 //上传头像 @RequestMapping(value = "/uploadHeadSculpture", method = RequestMethod ...

随机推荐

  1. 阿里云CentOS7系列三 -- 配置防火墙

    前面讲到了安装JDK以及Tomcat.但是大家会发现,当我们访问 http:// XXX.XXX.XXX.XXX:8080/80 时候,tomcat 猫并没有出现.原因就是没有设置防火墙. 再次介绍下 ...

  2. 大端模式 VS 小端模式

    简单点说,就是字节的存储顺序,如果数据都是单字节的,那怎么存储无所谓了,但是对于多字节数据,比如int,double等,就要考虑存储的顺序了.注意字节序是硬件层面的东西,对于软件来说通常是透明的.再说 ...

  3. JVM内存结构、垃圾回收那点事(转)

    翻看电脑的文件夹,无意看到了9月份在公司做的一次分享,浏览了一下"婆婆特",发现自己在ppt上的写的引导性问题自己也不能确切的回答出来,哎,知识这东西,平时不常用的没些日子就生疏了 ...

  4. 【JAVA】反射总结

    反射是什么? 反射就是指程序在运行的时候可以知道一个类的自身信息. 自身信息有哪些:类方法.属性.成员变量.构造方法.包等 动态编译和静态编译  静态编译:在编译的时候进确定类型,如果绑定对象成功,n ...

  5. 选择排序-C&num;

    选择排序包括:简单选择排序和堆排序 简单选择排序: 基本思路:从所有序列中先找到最小的,然后放到第一个位置.之后再看剩余元素中最小的,放到第二个位置……以此类推 /// <summary> ...

  6. C3D视频特征提取

    一.部署 1. 先把项目Clone下来 git clone https://github.com/jfzhang95/pytorch-video-recognition.git 2. 安装环境: Py ...

  7. Unity中UI界面颤抖解决方法

    将Render Mode中属性改为Screen Space - Camera 摄像机挂在Canvas属性下会出现UI界面颤抖的效果. UI界面颤抖解决方式:将Render Mode中属性改为Scree ...

  8. The end of the world

    这首63年乡村及流行排行榜双料亚军的歌曲,(Cashbox 年终冠军)据说原是作者为怀念亡父写就,虽是流行曲风,但由Skeeter Davis演唱,却赋予其不同的生命,在键盘连绵的三连音中,少女诉说着 ...

  9. ThreadLocal和ThreadLocalMap源码分析

    目录 ThreadLocal和ThreadLocalMap源码分析 背景分析 定义 例子 源码分析 ThreadLocalMap源码分析 ThreadLocal源码分析 执行流程总结 源码分析总结 T ...

  10. Swift学习笔记(十五)——程序猿浪漫之用Swift&plus;Unicode说我爱你

    程序猿经常被觉得是呆板.宅,不解风情的一帮人.可是有时候.我们也能够使用自己的拿手本领来表现我们的浪漫. 因为Swift语言是支持Unicode编码的,而Unicode最新已经支持emoji(绘文字) ...