@RequestMapping("/download") public ResponseEntity<byte[]> download(@RequestParam String fileName) { try { File path = new File(ResourceUtils.getURL("classpath:static").getPath()); if(!path.exists()) { path = new File(""); } File upload = new File(path.getAbsolutePath(),"/upload/"); if(!upload.exists()) { upload.mkdirs(); } File file = new File(upload.getAbsolutePath()+"/"+fileName); if(file.exists()){ /if(!fileService.canRead(file, SessionManager.getSessionUser())){ getResponse().sendError(403); }/ HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_OCTET_STREAM); headers.setContentDispositionFormData("attachment", fileName); return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(file),headers, HttpStatus.CREATED); } } catch (IOException e) { e.printStackTrace(); } return new ResponseEntity<byte[]>(HttpStatus.INTERNAL_SERVER_ERROR); }解释上述代码的逻辑
时间: 2023-06-12 17:04:33 浏览: 136
Spring 注解 开发模式 @Controller @RequestMapping @
5星 · 资源好评率100%
这是一个 Spring MVC 的 Controller 方法,处理一个名为 "/download" 的 GET 请求,参数为一个文件名 fileName。该方法的主要逻辑如下:
1. 获取静态资源目录的路径,如果不存在则获取当前项目的根目录路径。
2. 在静态资源目录下创建一个文件夹 "/upload",如果该文件夹不存在。
3. 根据文件名构建出文件对象,该文件对象位于 "/upload" 目录下。
4. 判断该文件是否存在,如果存在则继续执行,否则返回 500 状态码。
5. 如果需要进行权限控制,可以在注释部分进行控制。这里是判断当前登录用户是否有读取该文件的权限,如果没有则返回 403 状态码。
6. 构建一个 HttpHeaders 对象,设置 Content-Type 和 Content-Disposition 头部信息。
7. 使用 FileUtils 工具类将文件读取为字节数组,并构建一个 ResponseEntity 对象,设置字节数组、HttpHeaders 和 HttpStatus。
8. 返回该 ResponseEntity 对象,最终返回给客户端的就是文件的二进制数据。
阅读全文