第十七节:学习Hutool上传文件(自学Spring boot 3.x的第四天)

这节记录下如何使用Hutool库上传本地的文件到服务器端(因为是练习,所以是本地端)。

第一步:引入Hutool库最新版本,通过maven方式。(最新版本需去maven仓库查询)

第二步:编写一个postmapping方式的upload方法

复制代码
@RestController
public class UploadController {
    @Value("${upload.path}")
    private String uploadPath;

    @PostMapping("/upload")
    public Result upload(MultipartFile file) throws IOException {
        //获取文件名称
       String fileName =  file.getOriginalFilename();
       //获取文件的后缀
        String suffix = FileUtil.getSuffix(fileName);
        //对文件名做重命名操作
        //年/月/日/当前时间/时间戳-uuid.jpg
        //文件子路径
        String url = ObjectUtil.generateFileByTime()+ObjectUtil.generateFileBySecond()+"-"+ObjectUtil.generateUUID()+ StrUtil.DOT+suffix;
        //文件真实路径
        String filePath = uploadPath+url;
        InputStream inputStream = file.getInputStream();
        FileUtil.writeFromStream(inputStream,filePath);
       return Result.success(url);
    }
}

编写一个ObjectUtil的工具栏。

复制代码
public class ObjectUtil {
    /**
     * 对年月日进行格式化
     * @return
     */
    public  static String generateFileByTime(){
        DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
        return dateFormat.format(new Date()).replaceAll("-","/")+"/";
    }

    /**
     * 对时分秒进行格式化
     * @return
     */
    public  static String generateFileBySecond(){
        DateFormat dateFormat = new SimpleDateFormat("HH-mm-ss");
        return  dateFormat.format(new Date()).replaceAll("-","");
    }

    /**
     * 生成UUID并格式化
     * @return
     */
    public static String generateUUID(){
        return UUID.randomUUID().toString().replaceAll("-","");
    }

}

第三步:测试

第四步:开放该目录供外界访问

这里涉及到上节提到的自定义资源。在配置类中加上该文件的访问前缀和资源位置。

相关推荐
敲敲了个代码2 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
WanderInk3 小时前
刷新后点赞全变 0?别急着怪 Redis,这八成是 Long 被 JavaScript 偷偷“改号”了(一次线上复盘)
后端
吴佳浩4 小时前
Python入门指南(七) - YOLO检测API进阶实战
人工智能·后端·python
廋到被风吹走4 小时前
【Spring】常用注解分类整理
java·后端·spring
我命由我123455 小时前
SVG - SVG 引入(SVG 概述、SVG 基本使用、SVG 使用 CSS、SVG 使用 JavaScript、SVG 实例实操)
开发语言·前端·javascript·css·学习·ecmascript·学习方法
货拉拉技术5 小时前
出海技术挑战——Lalamove智能告警降噪
人工智能·后端·监控
最贪吃的虎5 小时前
Git: rebase vs merge
java·运维·git·后端·mysql
用户47949283569155 小时前
给客户做私有化部署,我是如何优雅搞定 NPM 依赖管理的?
前端·后端·程序员