下载附件

简介: 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>
目录
相关文章
|
6月前
|
前端开发
表单设计器附件的上传、显示和下载
表单设计器附件的上传、显示和下载
46 1
表单设计器附件的上传、显示和下载
|
编解码 Java 应用服务中间件
文件的上传和下载
文件的上传和下载
93 0
|
前端开发 Java Apache
文件上传与下载
文件上传与下载 文件上传也称为upload,是指将本地图片、视频、音频等文件上传到服务器上,可以供其他用户浏览或下载的过程。文件上传在项目中应用非常广泛,我们经常发微博、发微信朋友圈都用到了文件上传功能。 文件上传时,对页面的form表单有如下要求: method=“post” 采用post方式提交数据 enctype=“multipart/form-data” 采用multipart格式上传文件 type=“file” 使用input的file控件上传
利用微搭低代码实现附件的上传和下载
利用微搭低代码实现附件的上传和下载
利用微搭低代码实现附件的上传和下载
Redmine系统通过bug号解析页面内容及下载附件
Redmine系统通过bug号解析页面内容及下载附件
121 0
|
PHP 数据格式 XML
给微赞程序富文本编辑器加上传附件功能
微赞程序中,新闻编辑中,使用的ueditor,做了定制,去掉了一些按钮,但是一些情况下需要上传附件 如果给ueditor加上上传附件的图标,富文本编辑的调用是使用了以下函数的 function tpl_ueditor($id, $value = '', $options = array()) { 函数所在位置在/web/common/tpl.func.php这个文件中约985
2357 0
|
存储 Apache 安全
文件的上传和下载学习小结
文件的上传和下载学习小结 一、文件上传 客户端通过浏览器将文件上传至服务器。 对于我们写代码来说,就是IO操作。 二、实现文件上传 对表单有什么要求? 1. 提交方式必须为post 2. enctype="multipart/form-data" 3. 对于服务器的servlet有什么要求? request.getParameter("name"); 不能用该方式获取表单数据了,若非要用,则返回null。
1247 0
|
Web App开发 存储 Java
day18_文件的上传和下载学习笔记
一、文件的上传和下载 1、文件上传的原理分析 什么是文件上传?    要将客户端(浏览器)数据存储到服务器端,而不将数据直接存储到数据库中,而是要将数据存储到服务器所在的磁盘上,这就要使用文件上传。
1236 0
|
安全 Java
用proxyee-down快速下载百度网盘大文件
百度网盘下载大文件一直是一个痛点。现在国内基本上只有百度网盘可用了,但是免费用户使用百度网盘下载东西的速度一直不是很理想,所以现在有很多工具应运而生。今天要介绍的就是一个使用java编写的开源多线程下载器, 利用它,我们就可以满速下载百度云文件! 废话不多说,直接进入正题。
1606 0