【Springboot开发】后端代码基础框架

前言:主要介绍最基础的springboot开发架构

目录

  • 1. overall
  • 2. 配置文件
    • 2.1 YAML
    • 2.2 properties
    • 2.3 配置文件加载顺序
    • 2.4 多配置文件
  • 3. 代码包
    • 3.1 infrastructure
      • 3.1.1 persistence
    • 3.2 application
      • 3.2.1 dto
      • 3.2.2 converter
      • 3.2.3 service
    • 3.3 api
      • 3.3.1 vo
      • 3.3.2 req
      • 3.3.3 converter
      • 3.3.4 controller
  • **结语**

1. overall

在这里插入图片描述
核心部分主要是src包,main包存放的是后端代码,test是用于测试main包的代码。main包主要包含以下几个部分:

  • java:存放后端代码
  • resources:存放配置文件
  • webapp:存放资源文件,如前端jsp、图片资源等

2. 配置文件

springboot使用固定名字的配置文件:application.propertiesapplication.yml

2.1 YAML

基本语法

  • 使用缩进表示层级关系
  • 缩进时不允许使用Tab键,只允许使用空格
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  • 大小写敏感

yml举例

server:port: 8080

2.2 properties

properties举例:

spring.application.name=apply

2.3 配置文件加载顺序

  1. 按目录。位置高的将覆盖位置低的。
    在这里插入图片描述
  2. application.properties 的优先级高于 application.yml
  3. 互补读取:
  • 如果优先级高的配置文件中没有某个配置项,则会到优先级低的配置文件中找该配置项,即具有互补功能。
  • 文件名相同才会互补

2.4 多配置文件

有时候为了分开produce和test配置,会使用多个配置文件。
在这里插入图片描述
这种情况下可以在application.yml文件中指定使用的配置文件:
在这里插入图片描述

3. 代码包

代码包的路径为:
在这里插入图片描述
其中buildbaseframe为项目名。
后端代码主要包含以下几个部分:

  • BuildBaseFrameApplication: 启动类
  • utils:工具代码包
  • infrastructure
  • application
  • api

3.1 infrastructure

对应数据访问层,主要包含:

  • common包: 底层的一些公共配置
  • 模块包: 如用户模块
    在这里插入图片描述
    本节主要对各个模块包进行说明。

3.1.1 persistence

数据持久化层,主要包括mysqlrepository

  1. mysql
    主要是用来和数据库做绑定,映射对象到PO。
    在这里插入图片描述
    xml文件固定格式为:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.buildbaseframe.infrastructure.user.persistence.mysql.mapper.UserPoMapper"><select id="findThis" resultType="com.example.buildbaseframe.infrastructure.user.persistence.repository.po.UserPo">select *from t_userwhere id = #{id}</select>
</mapper>

namespace是为了绑定mysql包下对应的映射文件,下写各种sql操作语句。
xxxPoMapper文件是为了做数据库对象和PO对象的映射,举例:

@Mapper
public interface UserPoMapper extends BaseMapper<UserPo> {/*** 测试xml方式绑定查询*/UserPo findThis(@Param("id") Long id);}
  • PoMapper文件只需要写一个接口继承自BaseMapper,类型名为同名的Po类(自定义)
  • PoMapper文件的方法名和xml文件中的操作id需要一致
  • @Param传入参数也需要和xml对应
  1. repository
    主要操作PO对象。
    在这里插入图片描述
    PO包
    将数据库表结构映射到JAVA,举例:
@Data
@ToString(callSuper = true)
@EqualsAndHashCode(callSuper = true)
@TableName("t_user")
public class UserPo extends BaseDatabasePo {private static final long serialVersionUID = 1L;/*** 用户昵称*/@TableField(value = "name")private String nickname;/*** 用户头像url*/@TableField(value = "avatar_url")private String avatarUrl;/*** 用户个人介绍*/@TableField(value = "description")private String introduction;/*** 用户性别*/@TableField(value = "gender")private Integer gender;}

由于对PO对象有一些公共操作,通常先在common包中写一个公共类:

@Data
@EqualsAndHashCode(exclude = {"createTime", "updateTime"})
public class BaseDatabasePo implements Serializable {/*** 主键ID*/@TableId(value = "id", type = IdType.ASSIGN_ID)protected Long id;/*** 创建时间*/@TableFieldprotected LocalDateTime createTime;/*** 更新时间*/@TableFieldprotected LocalDateTime updateTime;}

repository接口
主要包含一些对数据对象的最基本的操作方法。举例:

public interface UserRepository {public UserPo get(Long userId);public int update(UserPo po, Long userId);public Long insertOneUser(UserPo userPo);
}

repository实现类
主要是对接口类的实现。

@Repository
public class UserRepositoryImpl implements UserRepository {@Autowiredprivate UserPoMapper mapper;@Overridepublic UserPo get(Long userId) {return mapper.selectById(userId);}@Overridepublic int update(UserPo po, Long userId) {UpdateWrapper<UserPo> wrapper = new UpdateWrapper<>();wrapper.eq("id", userId);if (po.getNickname() != null)wrapper.set("nickname", po.getNickname());if (po.getAvatarUrl() != null)wrapper.set("avatar_url", po.getAvatarUrl());if (po.getIntroduction() != null)wrapper.set("introduction", po.getIntroduction());if (po.getGender() != null)wrapper.set("gender", po.getGender());return mapper.update(po, wrapper);}@Overridepublic Long insertOneUser(UserPo userPo){mapper.insert(userPo);return userPo.getId();}
}
  • 先注入PoMapper对象,用于调用各种对数据库底层的操作

3.2 application

对应应用层,主要结构如下:
在这里插入图片描述

  • common包:公共配置,主要涉及到一些exception的处理
  • 各模块包
    主要讲解各模块包,结构如下,其中dto、converter、service是必须的:
    在这里插入图片描述

3.2.1 dto

前端给后端传递的数据,举例:

@Data
public class UserInfoDto {/*** 用户id*/private Long id;/*** 用户昵称*/private String nickname;/*** 用户头像url*/private String avatarUrl;/*** 用户个人介绍*/private String introduction;/*** 用户性别*/private GenderEnum gender;}

3.2.2 converter

只用写接口,具体方法会自动实现。用来实现Po和Dto对象之间的转换。

@Mapper(componentModel = "spring")
public interface UserAppConverter {UserInfoDto toUserInfoDto(UserPo po);UserPo toUserPo(UserInfoDto dto);}

3.2.3 service

服务层的接口和实现,用来实现和数据访问层的交互。
接口

public interface UserService {public UserInfoDto getUserInfo(Long userId);public UserInfoDto updateUserInfo(UserInfoDto dto, Long userId);public Long insertOneUser(UserInfoDto userInfoDto);
}

实现类

@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserRepository userRepository;@Autowiredprivate UserAppConverter userAppConverter;/*** 根据id获取用户信息* @param userId* @return*/@Overridepublic UserInfoDto getUserInfo(Long userId) {UserPo po = userRepository.get(userId);if (po == null) {throw new NotFoundException("用户信息");}System.out.println(po);return userAppConverter.toUserInfoDto(po);}/*** 更新用户信息* @param dto* @param userId* @return* @throws NotFoundException*/@Overridepublic UserInfoDto updateUserInfo(UserInfoDto dto, Long userId){UserPo po = userAppConverter.toUserPo(dto);if (userRepository.get(userId) == null) {throw new NotFoundException("用户信息");}int succ = userRepository.update(po, userId);return userAppConverter.toUserInfoDto(userRepository.get(userId));}/*** 添加新用户* @param userInfoDto* @return*/@Overridepublic Long insertOneUser(UserInfoDto userInfoDto){UserPo userPo = userAppConverter.toUserPo(userInfoDto);UserPo userPo1 = userRepository.findByName(userPo.getNickname());if(userPo1!=null){throw new BusinessException(ExceptionType.DUPLICATE_ERROR);}Long id = userRepository.insertOneUser(userPo);return id;}}

3.3 api

控制器层,目录结构如下:
在这里插入图片描述

  • common包:公共类,包括异常捕获、权限、page验证等功能
  • 各模块包
    主要讲解模块包,结构如下:
    在这里插入图片描述

3.3.1 vo

数据视图对象,后端传给前端的数据。

@Data
public class UserInfoVo {/*** 用户id*/private String id;/*** 用户昵称*/private String nickname;/*** 用户头像url*/private String avatarUrl;/*** 用户个人介绍*/private String introduction;/*** 用户性别*/private String gender;}

3.3.2 req

对vo对象做检查。

@Data
public class UserCreateReq {/*** 用户昵称*/@Length(min = 2, max = 64, message = "昵称长度应在2-64之间")private String nickname;/*** 用户头像url*/@URL(message = "头像应当是有效的图片url")@Length(max = 255, message = "头像URL长度不能超过255")private String avatarUrl;/*** 用户个人介绍*/@Length(max = 255, message = "用户介绍长度不能超过255")private String introduction;/*** 用户性别*/@EnumStringValidate(value = GenderEnum.class, message = "不是有效的性别类型")private String gender;}

3.3.3 converter

dto和vo对象的转换。

@Mapper(componentModel = "spring")
public interface UserApiConverter{@Mapping(source = "introduction", target = "description")UserInfoVo toUserInfoVo(UserInfoDto dto);@Mapping(source = "description", target = "introduction")UserInfoDto toUserInfoDto(UserCreateReq req);}

3.3.4 controller

api的实现。

@Validated
@RestController // 既需要返回html数据又需要返回非html数据,类上使用@controller,方法上@requestcontroller或@responsebody
@Slf4j
@RequestMapping("/api/v1/user")
public class UserController {@Autowiredprivate UserService service;@Autowiredprivate UserApiConverter userApiConverter;@Autowiredprivate GenderEnumConverter genderEnumConverter;/*** 用户获得自己的基本信息** @param* @return* @methodName getOwnInfo*/// 可以不用返回CommonResullt,有包装器会拦截@RequestMapping(value = "/info/own", method = RequestMethod.GET)public UserInfoVo getOwnInfo() {return userApiConverter.toUserInfoVo(service.getUserInfo(SecurityContextHolder.getUserId()));}/*** 根据id获得用户信息** @param* @return* @methodName getUserInfo*/@RequestMapping(value = "/info/{userId}", method = RequestMethod.GET)public UserInfoVo getUserInfo(@PathVariable("userId") String userId) {return userApiConverter.toUserInfoVo(service.getUserInfo(Long.valueOf(userId)));}}

结语

以上是关于springboot的一个基本框架的梳理,具体细节方面的实现需要根据实际需求修改。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/303232.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Django交易商场

Hello&#xff0c;我是小恒不会java 最近学习django&#xff0c;写了一个demo,学到了不少东西。 我在GitHub上开源了&#xff0c;提示‘自行查看代码&#xff0c;维护&#xff0c;运行’。 最近有事&#xff0c;先发布代码了&#xff0c;我就随缘维护更新吧 介绍&#xff1a; 定…

Harmony鸿蒙南向驱动开发-MIPI CSI

CSI&#xff08;Camera Serial Interface&#xff09;是由MIPI联盟下Camera工作组指定的接口标准。CSI-2是MIPI CSI第二版&#xff0c;主要由应用层、协议层、物理层组成&#xff0c;最大支持4通道数据传输、单线传输速度高达1Gb/s。 物理层支持HS&#xff08;High Speed&…

随机过程-BS定理

随机偏微分方程相比普通偏微分方程具有额外的随机项&#xff0c;反映了其描述的现象具有随机性质

华为 2024 届校园招聘-硬件通⽤/单板开发——第一套(部分题目分享,完整版带答案,共十套)

华为 2024 届校园招聘-硬件通⽤/单板开发——第一套 部分题目分享&#xff0c;完整版带答案(有答案和解析&#xff0c;答案非官方&#xff0c;未仔细校正&#xff0c;仅供参考&#xff09;&#xff08;共十套&#xff09;获取&#xff08;WX:didadidadidida313&#xff0c;加我…

贪心算法|860.柠檬水找零

力扣题目链接 class Solution { public:bool lemonadeChange(vector<int>& bills) {int five 0, ten 0, twenty 0;for (int bill : bills) {// 情况一if (bill 5) five;// 情况二if (bill 10) {if (five < 0) return false;ten;five--;}// 情况三if (bill …

基于ubuntu22.04系统安装nvidia A100驱动与NVLink启用

1、官方仓库 针对驱动包下载认准nvidia官网 dpkg -i nvidia-driver-local-repo-ubuntu2204-550.54.15_1.0-1_amd64.deb apt update apt search nvidia-driver-5502、安装 根据步骤1apt search nvidia-driver-550查出版本&#xff1a;此驱动包封在nvidia-driver-local-repo-ub…

数字社会下的智慧公厕:构筑智慧城市的重要组成部分

智慧城市已经成为现代城市发展的趋势&#xff0c;而其中的数字化转型更是推动未来社会治理体系和治理能力现代化的必然要求。在智慧城市建设中&#xff0c;智慧公厕作为一种新形态的信息化公共厕所&#xff0c;扮演着重要角色。本文智慧公厕源头实力厂家广州中期科技有限公司&a…

设计模式(22):解释器模式

解释器 是一种不常用的设计模式用于描述如何构成一个简单的语言解释器&#xff0c;主要用于使用面向对象语言开发的解释器和解释器设计当我们需要开发一种新的语言时&#xff0c;可以考虑使用解释器模式尽量不要使用解释器模式&#xff0c;后期维护会有很大麻烦。在项目中&…

Python:如何对FY3D TSHS的数据集进行重投影并输出为TIFF文件以及批量镶嵌插值?

完整代码见 Github&#xff1a;https://github.com/ChaoQiezi/read_fy3d_tshs&#xff0c;由于代码中注释较为详细&#xff0c;因此博客中部分操作一笔带过。 01 FY3D的HDF转TIFF 1.1 数据集说明 FY3D TSHS数据集是二级产品(TSHS即MWTS/MWHS 融合大气温湿度廓线/稳定度指数/…

CSS-语法、选择器

&#x1f4da;详见 W3scholl&#xff0c;本篇只做快速思维索引。 概述 CSS 是一种描述 HTML 文档样式的语言。 有三种插入样式表的方法&#xff1a; 外部 CSS内部 CSS行内 CSS &#x1f4c5; 外部 CSS 外部样式表存储在.css文件中。HTML 页面必须在 head 部分的<link&g…

ORAN C平面 Section Extension 22

ORAN C平面Section扩展22用于ACK/NACK请求。除section type 7外&#xff0c;section扩展22可以用于从O-DU发送到O-RU的所有section type和section扩展。 对于一个section描述&#xff0c;O-DU可以使用section扩展22要求O-RU使用section type 8 C平面消息进行ACK/NACK反馈。关于…

React路由快速入门:Class组件和函数式组件的使用

1. 介绍 在开始学习React路由之前&#xff0c;先了解一下什么是React路由。React Router是一个为React应用程序提供声明式路由的库。它可以帮助您在应用程序中管理不同的URL&#xff0c;并在这些URL上呈现相应的组件。 2. 安装 要在React应用程序中使用React路由&#xff0c;…

华为汽车的“计算+通信”电子电气架构

文章目录 整车结构 硬件平台 软件平台 总结展望 整车EEA&#xff08;电子电气架构&#xff09;&#xff0c;按照博世提出的演进路径&#xff0c;大致可以划分为四个阶段&#xff1a;分布式模块阶段、区域控制阶段、中央计算阶段、云计算阶段。示例如下&#xff1a; 本文选取…

联想电脑开启虚拟化失败,开启虚拟化却提示还没有开启虚拟化

安装虚拟机的时候&#xff0c; 电脑要开启虚拟化&#xff0c; Intel VT&#xff0c; 去BIOS开启了&#xff0c; 但是依然报错&#xff0c;说虚拟化处于禁用状态。 解决方案&#xff1a; 去联想官方&#xff0c;下载BIOS更新包&#xff0c;更新BIOS。 更新文档&#xff1a; 联…

vue中使用axios获取不到响应头Content-Disposition的解决办法

项目中&#xff0c;后端返回的文件流; 前端需要拿到响应头里的Content-Disposition字段的值&#xff0c;从中获取文件名 在控制台Headers中可以看到相关的字段和文件名&#xff0c;但是在axios里面却获取不到 如果想要让客户端访问到相关信息&#xff0c;服务器不仅要在head…

【算法刷题】八大排序算法总结(冒泡、选择、插入、二分插入、归并、快速、希尔、堆排序)

文章目录 八大排序算法总结1.冒泡排序2.选择排序3.插入排序4.二分插入排序5.归并排序6.快速排序7.希尔排序8.堆排序 八大排序算法总结 排序排序方法平均情况最好情况最坏情况空间稳定性1冒泡排序O(n2)O(n)O(n2)O(1)稳定2选择排序O(n2)O(n2)O(n2)O(1)不稳定3插入排序O(n2)O(n)O…

XUbuntu22.04之Typora添加水印并输出pdf文件(二百二十七)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀 优质视频课程:AAOS车载系统+AOSP…

30个Python操作小技巧

前言 1、列表推导 列表的元素可以在一行中进行方便的循环。 numbers [1, 2, 3, 4, 5, 6, 7, 8] even_numbers [number for number in numbers if number % 2 0] print(even_numbers)输出&#xff1a; 在这里插入代码片[1,3,5,7] 同时&#xff0c;也可以用在字典上。 d…

前端入门:极简登录网页的制作(未使用JavaScript制作互动逻辑)

必备工具&#xff1a;vscode Visual Studio Code - Code Editing. Redefined 目录 前言 准备 HTML源文件的编写&#xff08;构建&#xff09; head部分 body部分 网页背景设置 网页主体构建 CSS源文件的编写&#xff08;设计&#xff09; 结果展示 前言 博主稍稍自…

计算机视觉——引导APSF和梯度自适应卷积增强夜间雾霾图像的可见性算法与模型部署(C++/python)

摘要 在夜间雾霾场景中&#xff0c;可见性经常受到低光照、强烈光晕、光散射以及多色光源等多种因素的影响而降低。现有的夜间除雾方法常常难以处理光晕或低光照条件&#xff0c;导致视觉效果过暗或光晕效应无法被有效抑制。本文通过抑制光晕和增强低光区域来提升单张夜间雾霾…