首页 > 其他分享 >day03:菜品管理

day03:菜品管理

时间:2024-07-13 20:28:24浏览次数:16  
标签:文件 String 管理 day03 OSS 接口 菜品 上传

文章目录


数据库设计

image.png

公共字段填充

问题分析

在上一章节已经完成了员工管理菜品分类功能的开发,在新增员工新增菜品分类时需要在service的实现类中设置创建时间、创建人、修改时间、修改人等字段,在编辑员工编辑菜品分类时需要设置修改时间。修改人等字段。这些字段属于公共字段,也就是在我们该项目中很多表中都会有这些字段,如下:

序号字段名含义数据类型
1create_time创建时间datetime
2create_user创建人idbigint
3update_time修改时间datetime
4update_user修改人idbigint

而针对这些字段,我们的赋值方式为:

  1. 在新增数据时,将createTime、updateTime设置为当前时间,createUser、updateUser设置为当前登录ID。
  2. 在更新数据时,将createTime设置为当前时间,createUser设置为当前登录ID。

问题:如果都按照这样的方式来处理这些公共字段,需要在每一个业务方法中进行操作,编码相对冗余、繁琐,那能不能对于这些公共字段在某个地方进行统一处理,来简化开发呢?
答案:我们可以使用AOP编程,实现功能增强,来完成公共字段自动填充功能。

实现思路

  1. 对于Aop,我们使用过它是对某个类中的方法进行加强,而现在我们是对多个类中的新增修改方法来进行加强,那么切入点该怎么写呢,我们可以使用注解
  2. 我们可以在每个类中新增和修改的方法加上注解,将其设置为方法上注解,但是该怎么区分一个方法是新增还是修改方法呢?我们可以定义约束,来使用枚举
  3. 我们可以在枚举类中定义俩个值用来区分新增或者修改。(也可以定义默认值,设置一个值,总之能进行区分即可)
  4. 那么在controller、service、mapper这三层中我们该在哪个类中的新增和修改方法加注解呢?controller的方法中的参数是用来接收前端传过来的属性,而service是controller传过来的,mapper层的参数与数据表中的字段对应,所以我们在mapper层中的新增或修改方法加注解
  5. 在aop的切面类中我们可以在方法执行前进行填充
  6. 前置通知中JoinPoint可以获取到进行增强方法的参数方法对象,用获取到的来进行反射给公共字段进行填充

image.png
image.png

代码演示

  1. 枚举

image.png

  1. 注解

image.png

  1. 增强类

image.png

  1. mapper方法注解

image.png

新增菜品-文件上传

在新增菜品时,需要上传菜品对应的图片(文件),包括后续其他功能也会使用到文件上传,故要实现通用的文件上传接口

介绍

文件上传:是指将本地图片、视频、音频等文件上传到服务器上,可以供其他用户浏览或下载的过程。文件上传在项目中应用非常广泛,我们经常发抖音、发朋友圈都用到了文件上传功能

实现方式

  1. 直接将图片保存到服务的硬盘(springmvc中的文件上传)
    1. 优点:开发便捷,成本低
    2. 缺点:扩容困难
  2. 使用分布式文件系统进行存储
    1. 优点:容易实现扩容
    2. 缺点:开发复杂度稍大(有成熟的产品可以使用:FastDFS、MinIO)
  3. 使用第三方的存储服务(例如OSS)
    1. 优点:开发简单,拥有强大功能,免维护
    2. 缺点:付费

前端使用文件上传三要素

image.png

使用阿里云OSS服务进行文件存储

阿里云OSS

阿里云对象存储OSS(Object Storage Service):是一款海量、安全、低成本、高可靠的云存储服务。使用OSS,我们可以通过网络随时存储和调用包括文本、图片、音频和视频等在内的各种文件。
使用步骤
image.png
Bucket:存储空间是用户用于存储对象(Object,就是文件)的容器,所有的对象都必须隶属于某个存储空间。
SDK的依赖(jar包)、代码示例等,都可以叫做SDK

使用服务进行文件上传

  1. AliOssUtil工具类
@Data
@AllArgsConstructor
@Slf4j
public class AliOssUtil {

    private String endpoint;
    private String accessKeyId;
    private String accessKeySecret;
    private String bucketName;

    /**
     * 文件上传
     *
     * @param bytes
     * @param objectName
     * @return
     */
    public String upload(byte[] bytes, String objectName) {

        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);

        try {
            // 创建PutObject请求。
            ossClient.putObject(bucketName, objectName, new ByteArrayInputStream(bytes));
        } catch (OSSException oe) {
            System.out.println("Caught an OSSException, which means your request made it to OSS, "
                    + "but was rejected with an error response for some reason.");
            System.out.println("Error Message:" + oe.getErrorMessage());
            System.out.println("Error Code:" + oe.getErrorCode());
            System.out.println("Request ID:" + oe.getRequestId());
            System.out.println("Host ID:" + oe.getHostId());
        } catch (ClientException ce) {
            System.out.println("Caught an ClientException, which means the client encountered "
                    + "a serious internal problem while trying to communicate with OSS, "
                    + "such as not being able to access the network.");
            System.out.println("Error Message:" + ce.getMessage());
        } finally {
            if (ossClient != null) {
                ossClient.shutdown();
            }
        }

        //文件访问路径规则 https://BucketName.Endpoint/ObjectName
        StringBuilder stringBuilder = new StringBuilder("https://");
        stringBuilder
                .append(bucketName)
                .append(".")
                .append(endpoint)
                .append("/")
                .append(objectName);

        log.info("文件上传到:{}", stringBuilder.toString());

        return stringBuilder.toString();
    }
}

  1. 在MVC中创建AliOssUtil第三方Bean,交给Spring容器管理
@Configuration
@Slf4j
public class OssConfiguration {

    @Bean
    @ConditionalOnMissingBean
    public AliOssUtil aliOssUtil(AliOssProperties aliOssProperties){
        log.info("开始创建阿里云文件上传工具类对象:{}",aliOssProperties);
        return new AliOssUtil(aliOssProperties.getEndpoint(),
                aliOssProperties.getAccessKeyId(),
                aliOssProperties.getAccessKeySecret(),
                aliOssProperties.getBucketName());
    }
}

  1. 在Controller层写代码
@RestController
@RequestMapping("/admin/common")
@Slf4j
@Api(tags = "通用接口")
public class CommonController {

    @Autowired
    private AliOssUtil aliOssUtil;

    @PostMapping("/upload")
    @ApiOperation("上传文件接口")
    public Result<String> upload(MultipartFile file){
        log.info("文件上传:{}",file);

        try {
            //原始文件名
            String originalFilename = file.getOriginalFilename();
            //截取原始文件名的后缀   dfdfdf.png
            String extension = originalFilename.substring(originalFilename.lastIndexOf("."));
            //构造新文件名称
            String objectName = UUID.randomUUID().toString().replace("-","") + extension;

            //文件的请求路径
            String filePath = aliOssUtil.upload(file.getBytes(), objectName);
            return Result.success(filePath);
        } catch (IOException e) {
            log.error("文件上传失败:{}", e);
        }

        return Result.error(MessageConstant.UPLOAD_FAILED);
    }
}

下面是请求参数的方法:
image.png

新增菜品

接口设计

image.png

代码书写

image.png

分页查询

接口设计

image.png

代码书写

写多表查询,并返回DishVO
image.png

批量删除

接口设计

image.png

代码书写

image.png

修改菜品

先进行数据回显

接口设计

image.png

代码书写

image.png
:多表查询方式
多条sql方式查询:适合数据量大,互联网项目
一条sql方式查询(多表连接):适合数据量小,非互联网项目(企业内部使用的系统)

修改菜品

接口设计

image.png

代码书写

image.png

标签:文件,String,管理,day03,OSS,接口,菜品,上传
From: https://blog.csdn.net/m0_69266818/article/details/140405827

相关文章

  • springboot+vue+mybatis文化遗产管理系统+PPT+论文+讲解+售后
    信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古以来的短板,有效的提升管理的效率和业务水平。传统的管理模式,时间越久管理的内容越多......
  • 《项目管理》-笔记1
    PMBOK解读1.1项目和项目管理项目:项目是为创造独特的产品、服务或成果而进行的临时性工作。项目管理:在项目的活动中运用知识、技术、工具、技巧,以满足项目要求。1.2十大知识领域(1)项目整合管理项目整合管理包括为识别、定义、组合、统一和协调各项目管理过程组的各种过程和......
  • 基于SpringBoot的校园志愿者管理系统
    你好呀,我是计算机学姐码农小野!如果有相关需求,可以私信联系我。开发语言:Java数据库:MySQL技术:SpringBoot框架工具:MyEclipse、Tomcat系统展示首页个人中心志愿者管理活动信息管理摘要随着信息化时代的到来,管理系统趋向于智能化、系统化。校园志愿者管理系统的......
  • Python 潮流周刊#60:Python 的包管理工具真是多啊(摘要)
    本周刊由Python猫出品,精心筛选国内外的250+信息源,为你挑选最值得分享的文章、教程、开源项目、软件工具、播客和视频、热门话题等内容。愿景:帮助所有读者精进Python技术,并增长职业和副业的收入。本期周刊分享了13篇文章,13个开源项目,全文2300字。重要提醒:1、本专栏的......
  • Python—学生信息管理系统(附源码)
    今天所要分享的文章是关于如何实现学生管理系统,有需要的朋友可以参考一下,希望可以帮到大家!文章目录一、开始界面实现1.定义主函数2.运用循环,获取用户需求二、函数实现各个模块功能1.添加学生信息2.展示学生信息3.查找学生信息4.删除学生信息5.退出程序三、把......
  • useCookie函数:管理SSR环境下的Cookie
    title:useCookie函数:管理SSR环境下的Cookiedate:2024/7/13updated:2024/7/13author:cmdragonexcerpt:摘要:本文详述了useCookie函数在服务器端渲染(SSR)中的应用,包括读写Cookie、配置选项如maxAge、expires、httpOnly、secure、domain、path及SameSite,并提供了encode、......
  • 水利行业的智慧转型之路:结合物联网、大数据等先进技术,探讨智慧水利在提升管理效率、保
    目录引言一、智慧水利的内涵与意义(一)智慧水利的定义(二)智慧水利的意义二、关键技术支撑(一)物联网技术(二)大数据技术(三)云计算技术(四)人工智能技术三、应用实践探索(一)智慧水库管理(二)智慧河湖长制(三)智慧防汛抗旱(四)智慧节水灌溉四、未来展望1、技术融合创新2、标准化......
  • 智慧水利解决方案:从理论到实践的全面跨越,展示其在水资源管理、水灾害预警、水生态保护
    目录一、引言:智慧水利的时代背景与意义二、智慧水利的理论框架与技术体系1、理论框架2、技术体系三、智慧水利在水资源管理中的应用1、水资源优化配置2、水量水质协同管理四、智慧水利在水灾害预警中的应用1、洪水预警与应急响应2、干旱监测与评估五、智慧水利在水......
  • 8、Oracle中的创建和管理表
    最近项目要用到Oracle,奈何之前没有使用过,所以在B站上面找了一个学习视频,用于记录学习过程以及自己的思考。视频链接:【尚硅谷】Oracle数据库全套教程,oracle从安装到实战应用如果有侵权,请联系删除,谢谢。学习目标:描述主要的数据库对象创建表描述各种数据类型修改表的定义......
  • 基于ssm+vue.js+uniapp的汽车养护管理系统附带文章和源代码部署视频讲解等
    文章目录前言详细视频演示具体实现截图技术栈后端框架SSM前端框架Vue持久层框架MyBaits系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......