32.图片上传功能

上传图片功能

java 复制代码
 @PostMapping("blog")
    public ApiResponse uploadImage(@RequestParam("file") MultipartFile image) {

        try {
            //获取原始文件名称
            String originalFilename = image.getOriginalFilename();
            //生成新的文件名
            String fileName = createNewFileName(originalFilename);
            //保存文件
            image.transferTo(new File(UserConstant.IMAGE_UPLOAD_DIR, fileName));
            //返回结果
            log.debug("文件上传成功,{}", fileName);
            return ApiResponse.success(fileName);
        }catch (Exception e) {
            throw new RuntimeException("文件上传失败", e);
        }

    }

    private String createNewFileName(String originalFilename) {
        //获取后缀名
        String suffix = StrUtil.subAfter(originalFilename, ".", true);
        //生成目录
        String name = UUID.randomUUID().toString();
        int hash = name.hashCode();
        int d1 = hash & 0xF;
        int d2 = (hash >> 4) & 0xF;
        //判断目录是否存在
        File dir = new File(UserConstant.IMAGE_UPLOAD_DIR, StrUtil.format("/blogs/{}/{}", d1, d2));
        if(!dir.exists()) {
            dir.mkdirs();
        }
        //生成文件名
        return StrUtil.format("/blogs/{}/{}/{}.{}", d1, d2, name, suffix);
    }

分页查询功能

java 复制代码
@Override
    public List<Blog> queryHotBlog(Integer current) {
        //根据点赞数量倒序排列
        Page<Blog> page = query().orderByDesc("liked")
                .page(new Page<>(current, UserConstant.MAX_PAGE_SIZE));
        List<Blog> records = page.getRecords();
        //这里采用lambda表达式简写
        records.forEach(this::queryBlogUser);
        return records;
    }


/**
     * 给BLog对象添加用户信息
     * @param blog
     */
    private void queryBlogUser(Blog blog) {
        User user = userService.getById(blog.getUserId());
        blog.setName(user.getNickName());
        blog.setIcon(user.getIcon());
    }

注意lambda简写

mybatis中使用query()方法分页查询的写法

java 复制代码
@Override
    public void likeBlog(Integer id) {
        // update tb_blog set ... where
        update().setSql("liked = liked + 1").eq("id", id).update();
    }

mybatis中update()方法使用

相关推荐
李崧正14 分钟前
Java技术分享:Lambda表达式与函数式编程
java·开发语言·python
老了,不知天命16 分钟前
鳶尾花項目JAVA
java·开发语言·机器学习
二哈赛车手23 分钟前
新人笔记---实现简易版的rag的bm25检索(利用ES),以及RAG上传时的ES与向量数据库双写
java·数据库·笔记·spring·elasticsearch·ai
sthnyph23 分钟前
docker compose安装redis
redis·docker·容器
winner888126 分钟前
从零吃透C++命名空间、std、#include、string、vector
java·开发语言·c++
AI人工智能+电脑小能手34 分钟前
【大白话说Java面试题】【Java基础篇】第26题:Java的抽象类和接口有哪些区别
java·开发语言·面试
KmSH8umpK43 分钟前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第六篇
数据库·redis·分布式
bzmK1DTbd43 分钟前
SOLID原则在Java中的实践:单一职责与开闭原则
java·开发语言·开闭原则
winner88811 小时前
C++ 命名空间、虚函数、抽象类、protected 权限全套通俗易懂精讲(附与 Java 对比)
java·开发语言·c++
直奔標竿1 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring