java 以流的形式从服务器下载文件并保存到本地

本文详细介绍如何通过HTTP请求下载网站资源,包括客户端请求、服务器响应、文件存储和Java代码示例,重点展示FileDownloadUtil类的getInputStream和writeFile方法的使用。
摘要由CSDN通过智能技术生成

 

1.基本实现流程

          当我们想要下载网站上的某个资源时,我们会获取一个url,它是服务器定位资源的一个描述,下载的过程有如下几步:

           (1)客户端发起一个url请求,获取连接对象。

           (2)服务器解析url,并且将指定的资源返回一个输入流给客户。

           (3)建立存储的目录以及保存的文件名。

           (4)输出了写数据。

           (5)关闭输入流和输出流。

   2.实现方法的代码

@RequestMapping("/getFileByUrl")
    public void getImage(String filePath,String ccs_id, HttpServletRequest request, HttpServletResponse response) {
        // 从服务器端获得文件流,并输出到页面

        log.info("filePath---"+filePath);

        String queryString = request.getQueryString();
        String replace = queryString.replace("filePath=", "");
        log.info("queryString---"+replace);
        if (filePath.indexOf("ccs_id") == -1){
            log.info("ccs_id---"+ccs_id);
            filePath+="&ccs_id="+ccs_id;
        }

        InputStream inputStream = FileDownloadUtil.getInputStream(filePath);
        FileDownloadUtil.writeFile(response, inputStream);
    }
public class FileDownloadUtil {

    /**
     * @return
     * @description: 从服务器获得一个输入流
     */
    public static InputStream getInputStream(String urlPath) {
        InputStream inputStream = null;
        HttpURLConnection httpURLConnection = null;
        try {
            URL url = new URL(urlPath);
            httpURLConnection = (HttpURLConnection) url.openConnection();
            // 设置网络连接超时时间
            httpURLConnection.setConnectTimeout(3000);
            // 设置应用程序要从网络连接读取数据
            httpURLConnection.setDoInput(true);
            httpURLConnection.setRequestMethod("GET");
            int responseCode = httpURLConnection.getResponseCode();
            System.out.println("responseCode is:" + responseCode);
            if (responseCode == HttpURLConnection.HTTP_OK) {
                // 从服务器返回一个输入流
                inputStream = httpURLConnection.getInputStream();
            } else {
                inputStream = httpURLConnection.getErrorStream();
            }
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return inputStream;
    }

    /**
     * @param resp
     * @param inputStream
     * @description: 将输入流输出到页面
     */
    public static void writeFile(HttpServletResponse resp, InputStream inputStream) {
        OutputStream out = null;
        try {
            out = resp.getOutputStream();
            int len = 0;
            byte[] b = new byte[1024];
            while ((len = inputStream.read(b)) != -1) {
                out.write(b, 0, len);
            }
            out.flush();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                if (out != null) {
                    out.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

}

 

 

不一定需要先保存到本地再发送文件。如果你希望直接将数据发送为附件,可以使用`ByteArrayDataSource`来创建一个`DataSource`对象,并将其添加为附件。以下是修改后的代码示例: ```java // 导出数据到Excel文件并发送邮件 public void exportDataAndSendEmail() { // 查询数据库数据并获取结果集 List<Data> dataList = dataService.getDataList(); // 创建Excel工作簿 Workbook workbook = new HSSFWorkbook(); Sheet sheet = workbook.createSheet("Data"); // 创建表头 Row headerRow = sheet.createRow(0); headerRow.createCell(0).setCellValue("ID"); headerRow.createCell(1).setCellValue("Name"); // ... // 填充数据 int rowNum = 1; for (Data data : dataList) { Row row = sheet.createRow(rowNum++); row.createCell(0).setCellValue(data.getId()); row.createCell(1).setCellValue(data.getName()); // ... } try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) { // 保存Excel文件到字节数组输出 workbook.write(outputStream); // 创建一个JavaMailSender实例 JavaMailSenderImpl mailSender = new JavaMailSenderImpl(); // 配置邮件服务器参数 mailSender.setHost("smtp.example.com"); mailSender.setUsername("your-email@example.com"); mailSender.setPassword("your-password"); // 创建一个MimeMessage实例 MimeMessage message = mailSender.createMimeMessage(); try { // 设置邮件内容 MimeMessageHelper helper = new MimeMessageHelper(message, true); helper.setTo("recipient@example.com"); helper.setSubject("Data Export"); helper.setText("Please find the attached Excel file."); // 添加附件 ByteArrayDataSource dataSource = new ByteArrayDataSource(outputStream.toByteArray(), "application/vnd.ms-excel"); helper.addAttachment("data.xls", dataSource); // 发送邮件 mailSender.send(message); } catch (MessagingException e) { e.printStackTrace(); } } catch (IOException e) { e.printStackTrace(); } } ``` 这样,Excel文件将直接以字节数组的形式发送给收件人,而不需要将文件保存到本地磁盘。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值