springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项

作者:寒灵冰 时间:2023-09-04 09:17:26 

在使用easyUI做前端样式展示时,遇到了文件上传的问题,而且是在弹出层中提交表单,想做到不刷新页面,所以选择了使用ajaxFileUpload插件。提交表单时一直发现后台接收不到文件,后检查发现,原来是文件的id不对。

文件上传框我们定义如下:


<input class="easyui-filebox" id="image" name="image" data-options="label:'产品图片:',buttonText:'浏览',prompt:'仅支持jpg、gif、png等格式的图片',required:true">

提交的方式如下:


$.ajaxFileUpload({
 type:'POST',
 url : '${pageContext.request.contextPath}/product/saveProduct',
 secureuri : false,
 data : queryFormParam('#formId'),//需要传递的数据 json格式
 fileElementId :'image',
 dataType : 'json',
 success : function(data) { //上传成功后的回调。
   if(data.status){
     $.messager.alert("提示","保存成功");
   }else {
     $.messager.alert("提示","保存失败");
   }
 },
 error : function(data) {
   $.messager.alert("提示","异常,请稍后再试!");
 }
});

检查后发现,因easyui-filebox样式使用时,easyUI的js会为其创建一个type="file"的input,并且id也是easyUI定义的,自定义的id无效,可在easyUI的jquery.easyui.min.js中查看代码如下:


(function($){
var _551=0;
function _552(_553){
var _554=$.data(_553,"filebox");
var opts=_554.options;
opts.fileboxId="filebox_file_id_"+(++_551);
$(_553).addClass("filebox-f").textbox(opts);
$(_553).textbox("textbox").attr("readonly","readonly");
_554.filebox=$(_553).next().addClass("filebox");
var file=_555(_553);
var btn=$(_553).filebox("button");
if(btn.length){
$("<label class=\"filebox-label\" for=\""+opts.fileboxId+"\"></label>").appendTo(btn);
if(btn.linkbutton("options").disabled){
file.attr("disabled","disabled");
}else{
file.removeAttr("disabled");
}
}
};
function _555(_556){
var _557=$.data(_556,"filebox");
var opts=_557.options;
_557.filebox.find(".textbox-value").remove();
opts.oldValue="";
var file=$("<input type=\"file\" class=\"textbox-value\">").appendTo(_557.filebox);
file.attr("id",opts.fileboxId).attr("name",$(_556).attr("textboxName")||"");
file.attr("accept",opts.accept);
if(opts.multiple){
file.attr("multiple","multiple");
}
file.change(function(){
var _558=this.value;
if(this.files){
_558=$.map(this.files,function(file){
return file.name;
}).join(opts.separator);
}
$(_556).filebox("setText",_558);
opts.onChange.call(_556,_558,opts.oldValue);
opts.oldValue=_558;
});
return file;
};

表单中可以定义多个filebox,并且filebox的id为filebox_file_id_+序号,如果只有一个,那就是filebox_file_id_1,因我这边只有一个,然后将ajaxFileUpload提交时的fileElementId 改成‘filebox_file_id_1',后台就接收到image值了。

这个是看源码知道的,如果不看源码,其实可以直接用jQuery的方式获得id,如下:


var image_id= $("input[name='image']").attr("id");

因image名字在我的表单中是唯一的,所以通过名字来获得id,然后将id填入ajaxFileUpload的fileElementId 中即可达到同样的效果。

springMVC后台采用的是CommonsMultipartFile来接收文件,如下,得到路径后,用image.transferTo(saveDir);保存即可。


@RequestParam("image") CommonsMultipartFile image

以上所述是小编给大家介绍的springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项,希望对大家有所帮助

来源:http://blog.csdn.net/maozherong/article/details/70478116

标签:springmvc,easyui,ajaxfileupload,文件上传
0
投稿

猜你喜欢

  • MySQL如何查看正在运行的SQL详解

    2024-01-22 22:48:48
  • python tkinter实现屏保程序

    2023-02-20 14:31:20
  • Docker部署用Python编写的Web应用的实践

    2022-05-11 17:53:28
  • div水平垂直居中方法(淘宝招聘css题目)

    2007-10-25 12:48:00
  • oracle 常用的几个SQL

    2009-12-01 12:36:00
  • python引入不同文件夹下的自定义模块方法

    2023-04-24 18:37:22
  • PHP网站建设的流程与步骤分享

    2023-07-07 00:28:26
  • 分析描述CentOS mysql安装系统

    2010-10-25 20:34:00
  • MySQL5.6升级5.7时出现主从延迟问题排查过程

    2024-01-27 03:27:34
  • vue3.0如何使用computed来获取vuex里数据

    2024-04-28 09:24:20
  • vue3组合式API中setup()概念和reactive()函数的用法

    2024-05-22 10:42:13
  • pymongo中group by的操作方法教程

    2021-03-23 05:44:40
  • PHP的mysqli_sqlstate()函数讲解

    2023-06-08 14:30:30
  • asp文章中随机插入网站版权文字的实现代码

    2011-04-15 11:11:00
  • Python编程pydantic触发及访问错误处理

    2021-05-19 20:49:07
  • 解决vue.js在编写过程中出现空格不规范报错的问题

    2024-04-27 16:18:05
  • SQL 中having 和where的区别分析

    2024-01-17 17:23:24
  • openCV显著性检测的使用

    2022-10-20 12:25:02
  • Python中常见的加密解密算法总结

    2021-10-18 12:13:17
  • python使用信号量动态更新配置文件的操作

    2023-02-25 08:43:18
  • asp之家 网络编程 m.aspxhome.com