springboot 以IO流形式返回给前端

1、Controller

@ApiOperation(value = "IO流返回给前端")
@GetMapping("fileView")
public void fileView(@ApiParam(value = "文件路径", required = true) @RequestParam String fileUrl, HttpServletResponse response) {
    fileService.fileView(fileUrl, response);
}

2、Service

    /**
     * 以IO流的形式返回给前端
     *
     * @param fileUrl  文件路径
     * @param response resp
     */
    public void fileView(String fileUrl, HttpServletResponse response) {
        // 读取文件名 例:yyds.jpg
        String fileName = fileUrl.substring(fileUrl.lastIndexOf("/") + 1);
        try (FileInputStream inputStream = new FileInputStream(fileUrl);
             OutputStream outputStream = response.getOutputStream()) {
            byte[] data = new byte[1024];
            // 全文件类型(传什么文件返回什么文件流)
            response.setContentType("application/x-msdownload");
            response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\"");
            response.setHeader("Accept-Ranges", "bytes");
            int read;
            while ((read = inputStream.read(data)) != -1) {
                outputStream.write(data, 0, read);
            }
            // 将缓存区数据进行输出
            outputStream.flush();
        } catch (IOException e) {
            log.error("失败", e);
            throw new Exception("exception");
        }
    }

3、另外一种写法

如果为小文件,则可直接写入,无须循环,效率更高

byte[] data = new byte[inputStream.available()];
inputStream.read(data);
response.set
......
outputStream.write(data);
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用递归的方式遍历文件夹,并将文件夹及其子文件夹信息封装成树形结构返回前端。以下是一个示例代码: ```java import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.ResponseBody; import java.io.File; import java.util.ArrayList; import java.util.List; @Controller public class FileController { @GetMapping("/tree") @ResponseBody public List<TreeNode> getFileTree() { String rootPath = "D:/files"; // 文件夹根路径 File rootFile = new File(rootPath); if (!rootFile.exists() || !rootFile.isDirectory()) { return null; } TreeNode root = new TreeNode(rootFile.getName(), true); buildFileTree(root, rootFile); List<TreeNode> treeNodes = new ArrayList<>(); treeNodes.add(root); return treeNodes; } private void buildFileTree(TreeNode parent, File parentFile) { File[] files = parentFile.listFiles(); if (files != null && files.length > 0) { for (File file : files) { if (file.isDirectory()) { TreeNode treeNode = new TreeNode(file.getName(), true); parent.addChild(treeNode); buildFileTree(treeNode, file); } else { TreeNode treeNode = new TreeNode(file.getName(), false); parent.addChild(treeNode); } } } } private static class TreeNode { private String name; private boolean directory; private List<TreeNode> children; public TreeNode(String name, boolean directory) { this.name = name; this.directory = directory; } public String getName() { return name; } public boolean isDirectory() { return directory; } public List<TreeNode> getChildren() { return children; } public void addChild(TreeNode child) { if (children == null) { children = new ArrayList<>(); } children.add(child); } } } ``` 通过访问 `/tree` 接口,可以获取文件夹树形结构的数据,前端可以根据这些数据进行展示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值