excel模板文件下载与导入校验

本文介绍了如何下载Excel模板文件以及在导入后进行详细的数据校验,确保数据的准确性和完整性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下载模板文件

window.location.href = encodeURI(basePath + "/util/downtemplate.jsp?filename="+filename);

 

<%@page pageEncoding="UTF-8"%>
<%@page import="javax.servlet.ServletOutputStream"%>
<%@page import="java.io.*"%>
<%@page import="com.eos.web.taglib.util.*" %>
<%@ page import="java.net.URLEncoder" %>

<%
    InputStream bis = null;
    OutputStream bos = null;
    response.setCharacterEncoding("utf-8");
    String fileName = request.getParameter("filename");
    String filePath = "templatefile" + File.separator+fileName;
    System.out.println(filePath+"===");   
    // 解决中文乱码
    fileName = URLEncoder.encode(fileName, "utf-8");
    //System.out.println(fileName);
    try {

        response.setContentType("application/octet-stream");
        response.setHeader("Content-disposition", "attachment;filename=" + fileName); 
        response.setStatus(HttpServletResponse.SC_OK);
        
        bos = response.getOutputStream();
        byte[] buff = new byte[1024];
        int bytesRead;

        ServletContext sc = request.getSession().getServletContext();
        String serverRealPath = sc.getRealPath("/");
        serverRealPath = serverRealPath + filePath;
        // 路径分隔符转换
        serverRealPath = serverRealPath.replace("//", File.separator);
        System.out.println("========serverRealPath=======" + serverRealPath);

        bis = new FileInputStream(new File(serverRealPath));
        while (-1 != (bytesRead = bis.read(buff, 0, buff.length))) {
            bos.write(buff, 0, bytesRead);
        }
        bos.flush();
        out.clear();
        out = pageContext.pushBody();
    } catch (IOException e) {
        System.out.println("==========下载异常=========" + e.getMessage());
    } finally {
        if (bos != null) {
            try {
                bos.close();
            } catch (IOException e) {
                System.out.println(e.getMessage());
            }
        }
        if (bis != null) {
            try {
                bis.close();
            } catch (IOException e) {
                System.out.println(e.getMessage());
            }
        }
        
    }
    
%>

模板文件导入校验

var excelFile = $("#file").val();
var excelFile = $("#empItemFile").val();
if (excelFile=="") {
	nui.alert('请选择您要导入的Excel文件!');//请选择您要导入的Excel文件!
	return;
}
var re= /.xls$/;
if (!re.test(excelFile))
{
	nui.alert('请选择Excel文件!'); //请选择Excel文件!
	return;
}
excelFile = excelFile.substr(excelFile.lastIndexOf("\\") + 1);//校验是否是导出的模板文件

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值