下载附件

简介: 1、设置setContentType为application/x-msdownload2、设置Content-Disposition为附件形式并指定文件名称attachment;filename=contact.

1、设置setContentType为application/x-msdownload
2、设置Content-Disposition为附件形式并指定文件名称attachment;filename=contact.csv
3、根据文件路径创建输入流,response获取输出流
4、写入到输出流
5、删除缓存文件
6、关闭流

@RequestMapping(value = "/exportContact", method = RequestMethod.GET)
private void exportContact(HttpServletRequest request, HttpServletResponse response) {

    DBObject query = new BasicDBObject();
    String loginEmail = null;
    DataOutputStream os = null;
    InputStream is = null;
    String contactPath = null;
    try {
        //TODO:登录人信息,目前从配置文件中读取登陆人邮箱
        loginEmail = PropertyUtil.getMailProperties().getProperty("mail.email");
        query.put("emailAccount", loginEmail);

        //取得收件箱所有数据
        List<DBObject> list = wmPerService.getData(WmPerConstant.MONGODB_COLLECTION_CONTACT, query);

        List<String[]> contacts = new ArrayList<String[]>();
        for (DBObject entity : list) {
            String json = entity.toString();
            WmPerInfoDTO wmPerInfo = com.alibaba.fastjson.JSON.parseObject(json, WmPerInfoDTO.class);
            String[] contact =
                    {
                            wmPerInfo.getPerName(),
                            wmPerInfo.getPerEmail(),
                            wmPerInfo.getPerPhone(),
                            wmPerInfo.getPerProvinceName(),
                            wmPerInfo.getPerCityName(),
                            wmPerInfo.getPerCountyName(),
                            wmPerInfo.getPerStreetName(),
                            wmPerInfo.getPerDetailAddrss(),
                            wmPerInfo.getPerRemark()
                    };
//            {"姓名", "邮箱地址", "手机号码", "省", "市", "县/区", "乡镇/街道", "详细地址", "备注"};
            contacts.add(contact);
        }
        contactPath = CVSUtils.writeCsv(loginEmail, contacts);

        response.setContentType("application/x-msdownload");
        response.setHeader("Content-Disposition", "attachment;filename=contact.csv");
        is = new BufferedInputStream(new FileInputStream(contactPath));
        if (null != is){
            os = new DataOutputStream(response.getOutputStream());
            IOUtils.copy(is, os);
            os.flush();
        }
    } catch (Exception e) {
        logger.error("当前下载的附件不存在,或者下载附件错误", e);
    }
    finally {
        IOUtils.closeQuietly(is);
        IOUtils.closeQuietly(os);
        File file = new File(contactPath);
        file.delete();
    }

}

CSVUtils.java

/**
 * CSV文件导出工具类
 */
public class CVSUtils {
    public static final String FILE_EXTENSIONS = ".csv";
    public static final String CONTACT_FOLDER = "contact";
    public static final String CONTACT_PATH = CVSUtils.class.getClassLoader().getResource("/").getPath();
    public static final String[] heads = {"姓名", "邮箱地址", "手机号码", "省", "市", "县/区", "乡镇/街道", "详细地址", "备注"};

    //读取csv文件
    public static List<String[]> readCsv(String filePath) throws Exception {
        List<String[]> csvList = new ArrayList<String[]>();
        if (isCsv(filePath)) {
            CsvReader reader = new CsvReader(filePath, ',', Charset.forName("GBK"));

            while (reader.readRecord()) { //逐行读入除表头的数据
                csvList.add(reader.getValues());
            }
            reader.close();
        } else {
            System.out.println("此文件不是CSV文件!");
            throw new RuntimeException("此文件不是CSV文件!");
        }
        return csvList;
    }

    //判断是否是csv文件
    private static boolean isCsv(String fileName) {
        return fileName.matches("^.+\\.(?i)(csv)$");
    }

    //写入csv文件并返回文件路径
    public static String writeCsv(String fileName, List<String[]> contents) {
        try {
            String filePath = CONTACT_PATH.substring(0, CONTACT_PATH.length() - 8);
            String fileNameTemp = System.currentTimeMillis() + fileName + FILE_EXTENSIONS;
            String fileQualifiedName = filePath + CONTACT_FOLDER + File.separator + fileNameTemp;
            File csvFile = new File(fileQualifiedName);
            File parent = csvFile.getParentFile();//得到父目录
            if (parent != null && !parent.exists()) {
                parent.mkdirs();//创建文件夹
            }
            csvFile.createNewFile();//创建具体的文件

            CsvWriter wr = new CsvWriter(fileQualifiedName, ',', Charset.forName("GBK"));
            wr.writeRecord(heads);
            if (contents != null && contents.size() > 0) {
                for (String[] content : contents) {
                    wr.writeRecord(content);
                }
            }
            wr.close();
            return fileQualifiedName;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }

//    public static void writeCsv(Class<?> clazz) {
//        // Get all the declared fields
//        Field[] fields = clazz.getDeclaredFields();
//        LinkedList<Field> fieldList = new LinkedList<Field>();
//        int length = fields.length;
//        for (int i = -1; ++i < length; ) {
//            boolean isStaticField = Modifier.isStatic(fields[i].getModifiers());
//            if (isStaticField)
//                continue;
//            boolean isTransientField = Modifier.isTransient(fields[i].getModifiers());
//            if (isTransientField)
//                continue;
//            fieldList.add(fields[i]);
//        }
//        System.out.println(clazz.getName());
//    }
}

所需jar包

<dependency>
    <groupId>org.jumpmind.symmetric</groupId>
    <artifactId>symmetric-csv</artifactId>
    <version>3.5.19</version>
</dependency>
目录
相关文章
|
8月前
|
前端开发
表单设计器附件的上传、显示和下载
表单设计器附件的上传、显示和下载
55 1
表单设计器附件的上传、显示和下载
|
8月前
使用 responseentity进行文件的下载
使用 responseentity进行文件的下载
232 0
|
编解码 Java 应用服务中间件
文件的上传和下载
文件的上传和下载
99 0
|
Linux 开发工具 C++
|
JavaScript iOS开发
上传20M的ipa ,使用Appuploader工具只有2分钟左右即可上传成功
上传20M的ipa ,使用Appuploader工具只有2分钟左右即可上传成功
上传20M的ipa ,使用Appuploader工具只有2分钟左右即可上传成功
利用微搭低代码实现附件的上传和下载
利用微搭低代码实现附件的上传和下载
利用微搭低代码实现附件的上传和下载
|
Web App开发 存储 Java
day18_文件的上传和下载学习笔记
一、文件的上传和下载 1、文件上传的原理分析 什么是文件上传?    要将客户端(浏览器)数据存储到服务器端,而不将数据直接存储到数据库中,而是要将数据存储到服务器所在的磁盘上,这就要使用文件上传。
1242 0
|
存储 Apache 安全
文件的上传和下载学习小结
文件的上传和下载学习小结 一、文件上传 客户端通过浏览器将文件上传至服务器。 对于我们写代码来说,就是IO操作。 二、实现文件上传 对表单有什么要求? 1. 提交方式必须为post 2. enctype="multipart/form-data" 3. 对于服务器的servlet有什么要求? request.getParameter("name"); 不能用该方式获取表单数据了,若非要用,则返回null。
1253 0
|
安全 Java
用proxyee-down快速下载百度网盘大文件
百度网盘下载大文件一直是一个痛点。现在国内基本上只有百度网盘可用了,但是免费用户使用百度网盘下载东西的速度一直不是很理想,所以现在有很多工具应运而生。今天要介绍的就是一个使用java编写的开源多线程下载器, 利用它,我们就可以满速下载百度云文件! 废话不多说,直接进入正题。
1623 0

热门文章

最新文章