利用ajaxSubmit无刷新异步上传导入Excel,无刷新提交表单
来源:互联网 发布:康博软件 编辑:程序博客网 时间:2024/04/29 20:09
需要引用jquery.form.js文件,下载地址:http://download.csdn.net/detail/gorch/9630532
前台页面代码:
<script type="text/javascript" src="/js/jquery.js"></script><script type="text/javascript" src="/js/jquery.form.js"></script>
<form method="post" enctype="multipart/form-data" action="ImportExcel_DuiZhang.jsp" id="formImport"> <table width="100%" cellpadding="5px" id="diaTable" style="display:none;"> <tr> <td> <input type="file" name="uploadFile" id="uploadFile" style="width:290px" /> </td> </tr> <tr> <td style="text-align:center;padding-top:10px;"> <a href="javascript:submitImport()" id="btnOK">确定</a> </td> </tr> </table> </form>
<script> function submitImport(){ var epath = $('#uploadFile').val(); if(epath==""){ alert( '导入文件不能为空!'); return; } if(epath.substring(epath.lastIndexOf(".") + 1).toLowerCase()=="xlsx"){ alert( '03以上版本Excel导入暂不支持!'); return; } if (epath.substring(epath.lastIndexOf(".") + 1).toLowerCase()!="xls") { alert( '导入文件类型必须为excel!'); return; } $('#btnOK').linkbutton('disable'); $("#formImport").ajaxSubmit({ type: "post", dataType: "script", // 'xml', 'script', or 'json' (expected server response type) url: "ImportExcel_DuiZhang.jsp", success: function (data1) { $('#btnOK').linkbutton('enable'); if(data1.replace(/\s+/g,"")=="1"){ alert('导入成功'); location.reload(); }else{ alert(data1); } }, error: function (msg) { $('#btnOK').linkbutton('enable'); alert("文件上传失败"); } }); } </script>
ajaxSubmit 部分参数说明
dataType:期望返回的数据类型。null、“xml”、“script”或者“json”其中之一。dataType提供一种方法,它规定了怎样处理服务器的响应。这个被直接地反映到jQuery.httpData方法中去。下面的值被支持:
'xml':如果dataType == 'xml',将把服务器响应作为XML来对待。同时,如果“success”回调方法被指定, 将传回responseXML值。
'json':如果dataType == 'json', 服务器响应将被求值,并传递到“success”回调方法,如果它被指定的话。
'script':如果dataType == 'script', 服务器响应将求值成纯文本。
后台处理代码
<%@ page import="java.util.*" %><%@ page import="jxl.*"%><%@ page import="jxl.write.*"%><%@ page import="java.io.*"%><%@ page import="org.apache.commons.fileupload.RequestContext"%><%@ page import="org.apache.commons.fileupload.servlet.ServletRequestContext"%><%@ page import="org.apache.commons.fileupload.servlet.ServletFileUpload"%><%@ page import="org.apache.commons.fileupload.disk.DiskFileItemFactory"%><%@ page import="org.apache.commons.fileupload.FileItem"%>
try{response.setContentType("text/html");request.setCharacterEncoding("utf-8");// 声明文件域FileItem fileItem = null;// 从 HTTP servlet 获取 fileupload 组件需要的内容RequestContext requestContext = new ServletRequestContext(request);// 判断是否包含 multipart 内容,如果不包含,则不进行任何处理。if (ServletFileUpload.isMultipartContent(requestContext)) {// 创建基于磁盘的文件工厂DiskFileItemFactory factory = new DiskFileItemFactory();// 设置直接存储文件的极限大小,一旦超过则写入临时文件以节约内存。默认为 1024 字节factory.setSizeThreshold(1024 * 1024);factory.setRepository(new File(request.getSession().getServletContext().getRealPath("\\")));// 创建上传处理器,可以处理从单个 HTML 上传的多个上传文件。ServletFileUpload upload = new ServletFileUpload(factory);// 最大允许上传的文件大小upload.setSizeMax(10 * 1024 * 1024);try {// 处理上传List items = upload.parseRequest(requestContext);// 由于提交了表单字段信息,需要进行循环区分。for (int i = 0; i < items.size(); i++) {FileItem fi = (FileItem) items.get(i);// 如果不是表单内容,取出 multipart。if (!fi.isFormField()) {fileItem = fi;// 一次只上传单个文件break;}}Workbook workbook = null;Cell header = null;Cell cell = null;String currentColumn = "";InputStream uploadedStream = fileItem.getInputStream();workbook = Workbook.getWorkbook(uploadedStream);Sheet sheet = workbook.getSheet(0);//返回去掉空行的记录数int nullCellNum;//统计空格数int row = sheet.getRows();int column = sheet.getColumns();int actualRows = row;for (int m = 0; m < row; m++) { //统计行中为空的单元格数 nullCellNum = 0; for (int n = 0; n < column; n++) { String val = sheet.getCell(n, m).getContents(); val = StringUtils.trimToEmpty(val); if (StringUtils.isBlank(val)) nullCellNum++; } if (nullCellNum >= column) { //如果nullCellNum大于或等于总的列数 actualRows--; //行数减一 }}String dzTitle=sheet.getCell(1, 1).getContents().trim();String lifnr=sheet.getCell(1, 2).getContents().trim();//补0try{lifnr="0000"+Integer.parseInt(lifnr);}catch(Exception ep1){}if(null==dzTitle||"".equals(dzTitle)){out.print("对账单标题为空");}else if(null==lifnr||"".equals(lifnr)){out.print("物流商编码为空");}else{//一系列处理过程......out.print("1");}}catch (Exception ex) {out.print("Exception2:"+ex.getMessage());}}else{out.print("读取文件失败");}}catch (Exception ex) {out.print("Exception3:"+ex.getMessage());}
1 0
- 利用ajaxSubmit无刷新异步上传导入Excel,无刷新提交表单
- 利用ajaxSubmit无刷新异步上传导入Excel,无刷新提交表单
- 利用ajaxSubmit无刷新异步上传导入Excel,无刷新提交表单
- Jquery ajaxsubmit 异步上传图片 无刷新
- 无刷新文件上传 ajax提交表单
- 无刷新文件上传 ajax提交表单
- 无刷新文件上传 ajax提交表单
- 关于form表单无刷新提交上传
- 利用iframe实现表单无刷新上传
- jquery异步提交无刷新
- jQuery提交表单, 无刷新
- iframe 无刷新提交表单
- iframe无刷新提交表单
- 无刷新提交form表单
- 异步无刷新上传,积累
- ajax(iframe)无刷新提交表单、上传文件
- ajax(iframe)无刷新提交表单、上传文件
- 利用iframe实现表单的无刷新提交
- JavaEE项目实战(OA系统)之十二_部门管理之六
- 毛超帅四.Radmin远程链接分享(java4)______软件开发-帮助类
- 安卓开发之自定义带加载进度的按钮ProgressButton
- Android 利用handler在线程之间传递代码
- 单例模式的多种实现
- 利用ajaxSubmit无刷新异步上传导入Excel,无刷新提交表单
- asp解密chrw、chr编码文件- 58OA 网维系统解密
- Java NIO 系列教程
- android:layout_gravity和android:gravity的区别
- Spring的面试终极问答
- HDU 2084 数塔
- 7.4 D HDU 5652India and China Origins
- c#重写,覆盖,隐藏,重载,继承
- margin和padding的区别