如何在不使用OpenCsv编写的情况下下载csv文件

时间:2013-10-22 06:18:25

标签: java servlets csv

我正在使用OpenCsv API,现在我遇到了一些问题。这是我的代码

protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();

        try {
            List<UserRegData> userRegDataList = new ArrayList<UserRegData>();
            HttpSession session = request.getSession();
            userRegDataList = (List<UserRegData>) session.getAttribute("referralData");
            List<String[]> dataToWrite = new ArrayList<String[]>();
            String csv = "E:\\carewave_backup\\csv\\UserReferral.csv";
            CSVWriter writer = new CSVWriter(new FileWriter(csv));

            for (UserRegData obj : userRegDataList) {
                dataToWrite.add(new String[]{obj.getReferred_by_name(), obj.getInvitee_name(), obj.getInvitee_email(), obj.getInvitee_date(), obj.getIsInviteeRegistered(), obj.getDate_of_invitee_registered()});
            }
            writer.writeAll(dataToWrite);
            writer.close();
        } catch (Exception ex) {
            ex.printStackTrace();
        } finally {
            out.close();
        }
    }

这个servlet基本上从会话中检索列表并将其写入csv文件。这个servlet在用户点击下载csv按钮后触发。现在我需要的是,浏览器应该给出一个下载对话框。无论如何都要以csv格式下载它没有先将它写入文件?。

1 个答案:

答案 0 :(得分:0)

我假设您正在询问如何将服务器上的输出直接流式传输到客户端,而无需先将其写入服务器上的临时文件。

您不需要先将数据写入文件。

  1. 将共鸣内容类型设置为text/csv
  2. 在响应对象上调用getOutputStream()
  3. dataToWrite的内容作为单独的行写入输出流
  4. 不需要磁盘文件。