前后端分离实战2----后端

戳我抵达前端

项目描述:用Vscode创建Spring Boot+mybatis项目,用maven进行管理。创建一个User表,对其内容进行表的基本操作(增删改查),显示在前端。

项目地址:戳我一键下载项目

运行效果如下:

项目目录:

核心代码讲解:

1.UserController.java

package improv1.improv1;
import improv1.improv1.MybatisConnect.MyBatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.springframework.web.bind.annotation.*;import java.time.LocalDateTime;
import java.util.HashMap;
import java.util.List;
import java.util.Map;@RestController
@RequestMapping("/user")
public class UserController {// 新增用户@PostMapping("/add")public Map<String, Object> addUser(@RequestParam String name, @RequestParam String email) {Map<String, Object> result = new HashMap<>();if (name == null || email == null) {result.put("error", "参数不足,需提供 name 和 email");return result;}try (SqlSession session = MyBatisUtil.getSqlSession()) {UserMapper mapper = session.getMapper(UserMapper.class);Map<String, Object> params = new HashMap<>();params.put("name", name);params.put("email", email);params.put("createTime", LocalDateTime.now());int rows = mapper.insertUser(params);session.commit();result.put("message", "新增成功");result.put("rows", rows);result.put("id", params.get("id"));} catch (Exception e) {result.put("error", e.getMessage());}return result;}// 查询所有用户@GetMapping("/list")public List<Map<String, Object>> getAllUsers() {try (SqlSession session = MyBatisUtil.getSqlSession()) {UserMapper mapper = session.getMapper(UserMapper.class);return mapper.getAllUsers();}}// 更新用户@PostMapping("/update")public Map<String, Object> updateUser(@RequestParam Integer id,@RequestParam String name,@RequestParam String email) {Map<String, Object> result = new HashMap<>();if (id == null || name == null || email == null) {result.put("error", "参数不足,需提供 id、name、email");return result;}try (SqlSession session = MyBatisUtil.getSqlSession()) {UserMapper mapper = session.getMapper(UserMapper.class);Map<String, Object> params = new HashMap<>();params.put("id", id);params.put("name", name);params.put("email", email);int rows = mapper.updateUser(params);session.commit();result.put("message", "更新成功");result.put("rows", rows);} catch (Exception e) {result.put("error", e.getMessage());}return result;}// 删除用户@PostMapping("/delete")public Map<String, Object> deleteUser(@RequestParam Integer id) {Map<String, Object> result = new HashMap<>();if (id == null) {result.put("error", "请提供要删除的用户ID");return result;}try (SqlSession session = MyBatisUtil.getSqlSession()) {UserMapper mapper = session.getMapper(UserMapper.class);int rows = mapper.deleteUser(id);session.commit();result.put("message", "删除成功");result.put("rows", rows);} catch (Exception e) {result.put("error", e.getMessage());}return result;}
}

解析:

操作数据库表一般把对一张表的操作写在一个文件里。

Spring Boot项目把文件写成controller,默认会部署到tomcat,可以通过htttp://localhost:8080/映射地址来访问。这里的映射地址是由前缀+映射子地址组成的,在这里若要查询表映射地址为/user/list。若要删除表,完整的地址是htttp://localhost:8080/user/delete剩下的以此类推。

2.mybatis框架应用部分

如果要在spring Boot项目里用mybatis框架管理表,首先,要在resources目录下建立mapper文件夹,在里面编写,数据库表对应的mapper.xml文件。可以在resouces根目录下编写mybatis-config.xml文件。

当然,最好不要编写mybatis-config文件,在application.properties里填写相关数据库信息进行统一管理比较好。接着,在pom.xml文件里加入Spring Boot和mybatis以及数据库相关依赖。

最后,在项目里编写mapper.xml对应的操作数据库表接口文件,对表进行操作。

一般要添加的pom.xml内容如下:

	<!-- Spring boot配置mybatis -->
<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>3.0.4</version></dependency><!-- 配置mysql数据库--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.33</version>
</dependency><!-- 配置spring boot--></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency>

1)UserMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="improv1.improv1.UserMapper"><!-- 插入用户 --><insert id="insertUser" parameterType="map">INSERT INTO user(name, email, create_time)VALUES(#{name}, #{email}, #{createTime})</insert><!-- 删除用户 --><delete id="deleteUser" parameterType="int">DELETE FROM user WHERE id = #{id}</delete><!-- 更新用户 --><update id="updateUser" parameterType="map">UPDATE user SETname = #{name},email = #{email}WHERE id = #{id}</update><!-- 查询所有用户 --><select id="getAllUsers" resultType="map">SELECT id, name, email, create_time as createTimeFROM user</select>
</mapper>

解析:

  其中INSERT INTO user(name, email, create_time)
        VALUES(#{name}, #{email}, #{createTime})这里的user(属性)和values(#{属性}),要保持一致。id与mapper.xml对应的操作类方法名对应一致

2)UserMapper.java

package improv1.improv1;
import java.util.List;
import java.util.Map;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("improv1.improv1")
public interface UserMapper {// 使用Map作为参数int insertUser(Map<String, Object> params);int deleteUser(int id);int updateUser(Map<String, Object> params);List<Map<String, Object>> getAllUsers();
}

解析:

1.这里的MapperScan的作用是用于自动扫描和注册 MyBatis 的 Mapper 接口。如果不配置,可能就会报错找不到mapper。

2.这里的getAllUsers返回的结果要进行接受显示,所以我们把返回类型用List数组来接收,每一个元素都是键值对的形式对应数据库表里的每一行数据。

3)application.properties

spring.application.name=improv1
# 数据库连接配置
spring.datasource.url=jdbc:mysql://localhost:3306/mybaitistest?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver# MyBatis 配置
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=improv1.improv1 # 你的实体类包名
mybatis.configuration.log-impl=org.apache.ibatis.logging.slf4j.Slf4jImpl

解析:

mybatis.type-aliases-package=improv1.improv1 这里配置的就是操作数据库表的类所在包的位置。

3.CorsConfig.java

package improv1.improv1;import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configuration
public class CorsConfig {@Beanpublic WebMvcConfigurer corsConfigurer() {return new WebMvcConfigurer() {@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**").allowedOriginPatterns("*").allowedMethods("*").allowedHeaders("*").allowCredentials(true);}};}
}

解析:

这段代码是一个Spring Boot的CORS(跨域资源共享)配置类,用于全局配置跨域请求。主要功能包括:

  • 允许所有路径(/**)的跨域请求
  • 允许所有来源(allowedOriginPatterns("*")
  • 允许所有HTTP方法(allowedMethods("*")
  • 允许所有请求头(allowedHeaders("*")
  • 允许携带凭证(allowCredentials(true))如果不写,就可能会引发浏览器访问受阻,访问失败报200错误。其实这些配置也可以写在application.properties里面,但是这样这种方式只适用于简单场景,且部分老版本 Spring Boot 可能不支持。如果你需要更细粒度的控制(如只允许部分接口、部分域名),还是建议使用 Java 配置类。

扩展:

1.postMapper和getMapper的区别

定义与用途 postMapper通常指代处理HTTP POST请求的映射器,用于接收客户端提交的数据(如表单、JSON等),适用于数据修改或新增操作。getMapper则对应HTTP GET请求的映射器,用于获取资源,适合数据查询场景。

数据传递方式 postMapper通过请求体(body)传输数据,数据在HTTP包体中,适合传输大量或敏感信息。getMapper通过URL参数传递数据,数据附加在URL后,长度受限且可见。

安全性 postMapper相对更安全,数据不直接暴露在URL中,适合密码等敏感信息。getMapper参数明文显示在URL,可能被日志或浏览器历史记录留存。

幂等性 getMapper具有幂等性,多次执行同一请求不会改变资源状态。postMapper通常是非幂等的,重复提交可能导致多次资源变更。

2.@RequestMapping("/user")是什么怎么用

作用与含义

  • 路径映射:将特定 URL 路径(如 /user)与控制器(Controller)类或方法绑定。
  • 请求处理:当客户端请求匹配该路径时,Spring 会调用对应的控制器方法处理请求。

使用方法

类级别注解

标注在控制器类上,定义该控制器所有方法的公共路径前缀:

@Controller
@RequestMapping("/user")
public class UserController {// 方法实际路径为 /user/profile@RequestMapping("/profile")public String profile() {return "profile";}
}
方法级别注解

标注在具体方法上,定义独立路径:

@Controller
public class UserController {// 直接响应 /login 路径@RequestMapping("/login")public String login() {return "login";}
}
组合使用

类注解定义前缀,方法注解补充子路径:

@RestController
@RequestMapping("/api/user")
public class UserApiController {// 完整路径为 /api/user/info@GetMapping("/info")public UserInfo getInfo() {return userService.getInfo();}
}
支持的属性

可通过额外属性进一步定义请求匹配规则:

@RequestMapping(value = "/create",method = RequestMethod.POST,consumes = "application/json",produces = "application/json"
)
常见派生注解
  • @GetMapping:等价于 @RequestMapping(method = RequestMethod.GET)
  • @PostMapping:等价于 @RequestMapping(method = RequestMethod.POST)
  • @PutMapping/@DeleteMapping 等同理

该注解是 Spring Web 开发的核心配置方式,合理使用可实现清晰的 URL 路由结构。

3.mapper.xml中的id是怎么用的

id 的作用

在 MyBatis 的映射文件(XML 文件)中,id 是 <insert> 标签的一个属性,用于唯一标识该 SQL 语句。id 的主要作用是让 MyBatis 能够通过它找到对应的 SQL 语句并执行。

id 的用途

id 与 Mapper 接口中的方法名一一对应。例如,如果 Mapper 接口中有一个方法名为 insertUser,那么在映射文件中,<insert> 标签的 id 也必须是 insertUser,这样才能正确关联接口方法与 SQL 语句。

使用方法

  1. 定义 Mapper 接口
    在 Mapper 接口中声明一个方法,方法名与映射文件中的 id 一致。

    public interface UserMapper {int insertUser(User user);
    }
  2. 在映射文件中配置 SQL
    映射文件中的 <insert> 标签的 id 必须与接口方法名相同。

    <insert id="insertUser" parameterType="map">INSERT INTO user(name, email, create_time)VALUES(#{name}, #{email}, #{createTime})
    </insert>
  3. 调用方法
    通过 MyBatis 的 SqlSession 或 Mapper 代理对象调用接口方法,MyBatis 会根据 id 找到对应的 SQL 并执行。

    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
    Map<String, Object> params = new HashMap<>();
    params.put("name", "John");
    params.put("email", "john@example.com");
    params.put("createTime", new Date());
    userMapper.insertUser(params);

注意事项

  • id 必须在同一个命名空间(namespace)内唯一,不能重复。
  • id 的值应与 Mapper 接口中的方法名严格匹配,否则会导致 MyBatis 无法找到对应的 SQL 语句。
  • 如果使用注解方式(如 @Insert),则无需在 XML 中配置 id,但方法名仍需与 SQL 逻辑对应。

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

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

相关文章

深入 ARM-Linux 的系统调用世界

1、引言 本篇文章以 ARM 架构为例&#xff0c;进行讲解。需要读者有一定的 ARM 架构基础 在操作系统的世界中&#xff0c;系统调用&#xff08;System Call&#xff09;是用户空间与内核空间沟通的桥梁。用户态程序如 ls、cp 或你的 C 程序&#xff0c;无权直接操作硬件、访问文…

LabVIEW键盘鼠标监测控制

通过Input Device Control VIs&#xff0c;实现对键盘和鼠标活动的监测。通过AcquireInput Data VI 在循环中持续获取输入数据&#xff0c;InitializeKeyboard与InitializeMouse VIs 先获取设备ID 引用&#xff0c;用于循环内监测操作&#xff1b;运行时可输出按键信息&#xf…

Linux 系统管理:自动化运维与容器化部署

在现代 IT 基础设施中&#xff0c;自动化运维和容器化部署是提高系统管理效率和可维护性的关键。Linux 系统因其稳定性和灵活性而被广泛应用于服务器和数据中心。本文将深入探讨 Linux 系统管理中的自动化运维和容器化部署技术&#xff0c;帮助系统管理员实现高效运维和快速部署…

直播 APP 开发需要多少成本

直播行业的火爆催生了大量直播 APP 开发需求&#xff0c;而开发成本是开发者最关注的问题之一。其成本构成复杂&#xff0c;受功能需求、开发方式、技术难度等多种因素影响。​ 基础功能开发是成本的重要组成部分。用户注册登录、直播间创建与管理、视频播放、聊天互动等功能开…

Reactor操作符的共享与复用

在 Reactor 中&#xff0c;transform 和 transformDeferred 是两个用于代码复用和操作符链封装的高级操作符。它们允许你将一组操作符封装成一个函数&#xff0c;并在适当的时候应用到响应式流中。以下是它们的详细总结&#xff1a; 1. transform 操作符 作用&#xff1a;tran…

C#中的Converter详解

Converter是C#中一个非常有用的概念&#xff0c;主要用于类型转换。它通常以委托或接口的形式出现&#xff0c;允许开发者定义如何将一种类型转换为另一种类型。下面我将详细介绍Converter的概念、使用场景&#xff0c;并以布尔型转换为例展示具体应用。 Converter的基本概念 …

LabVIEW荧光微管图像模拟

利用LabVIEW平台&#xff0c;集成 PI 压电平台、Nikon 荧光显微镜及Andor sCMOS 相机等硬件&#xff0c;构建荧光微管滑行实验图像序列模拟系统。通过程序化模拟微管运动轨迹、荧光标记分布及显微成像过程&#xff0c;为生物医学领域微管跟踪算法测试、运动特性分析提供标准化仿…

CentOS下Nginx服务器搭建全攻略

Nginx 安装与配置完整指南 一、安装 Nginx 1.1 添加 Nginx 官方仓库 在 CentOS 系统中&#xff0c;默认仓库的 Nginx 版本可能较旧&#xff08;通常为 1.12 或更早版本&#xff09;&#xff0c;建议添加官方仓库来安装最新稳定版本&#xff08;目前为 1.25.x&#xff09;&am…

网络拓扑图绘制全流程:从架构解析到工具实战

在数据呈现与系统管理中&#xff0c;清晰展示设备间的逻辑关系至关重要。网络拓扑图正是这样一种有效的可视化工具。它通过节点设备和连接线路&#xff0c;直观呈现网络结构或项目流程中各元素的布局与交互关系&#xff0c;帮助理解系统运作、诊断问题并确保项目顺利进行。 1. …

Git 简介安装教程

&#x1f4e2;欢迎点赞&#x1f44d;收藏⭐留言&#x1f4dd;如有错误敬请指正&#xff01; 目录 一、Git 的安装1.1 Git 的下载1.2 Git 的安装1.2.1 使用许可声明1.2.2 选择安装目录1.2.3 选择安装组件1.2.4 选择开始菜单文件夹1.2.5 选择 Git 默认编辑器1.2.6 决定初始化新项…

鸿蒙NEXT-鸿蒙三层架构搭建,嵌入HMRouter,实现便捷跳转,新手攻略。(2/3)

在上一小节我们已经完成了关于三层架构的搭建&#xff0c;接下来我们来实现在三层架构中的导入依赖&#xff0c;将他们相互联系起来。 第一步&#xff1a;在features产品定制层中&#xff0c;对其中所有的动态共享包导入依赖&#xff0c;示例features>my>oh-package.jso…

【每天一个知识点】语料投毒(Corpus Poisoning)

“语料投毒”&#xff08;Corpus Poisoning&#xff09; 是指攻击者通过向大型语言模型&#xff08;如 ChatGPT&#xff09;使用的外部知识库中注入恶意或误导性文档&#xff0c;从而干扰模型的检索与回答过程&#xff0c;导致其输出错误、虚假或有害内容。 &#x1f50d; 举个…

疏通经脉: Bridge 联通逻辑层和渲染层

本节概述 经过前面两节的开发&#xff0c;我们已经完成了小程序逻辑线程和 UI 线程的启动引擎准备&#xff0c;这节开始&#xff0c;我们将完善 native bridge 层的搭建&#xff0c;构建起逻辑线程和UI线程之间的桥梁。 开始之前我们先来回顾一下逻辑引擎小节相关的流程图: 一…

【攻防篇】解决:阿里云docker 容器中自动启动xmrig挖矿

解决&#xff1a;阿里云服务器docker容器被植入挖矿程序 **1. 紧急处理&#xff1a;停止挖矿进程****&#xff08;1&#xff09;查找并终止 xmrig 进程****&#xff08;2&#xff09;删除恶意文件** **2. 清理被感染的容器****&#xff08;1&#xff09;停止并删除容器****&…

对称非对称加密,https和http,https通讯原理,Charles抓包原理

文章目录 对称加密的非对称加密http和https原理TCP三次握手四次挥手https通讯流程&#xff1a;Charles抓包原理 对称加密的非对称加密 对称加密&#xff1a;发送方的接收方式使用同一个秘钥进行加密和解密&#xff0c;发送方将需要发送的数据&#xff0c;选择某种加密算法&…

Kubernetes(K8s)_15_调度原理

文章目录 Pod调度实现原理调度队列优先队列底层数据 调度缓存调度框架 Pod调度 Pod调度: 通过污点、容忍度和亲和性影响Pod的调度 调度器实现, 其基于配置器构造(其配置来源于配置API)调度过程中任何插件返回拒绝, 都会导致Pod可能再次返回调度队列 如: Pod调度简略流程 调度…

moduo之tcp客户端TcpClient

结构 #mermaid-svg-muvN6eOMXA4rCyXP {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-muvN6eOMXA4rCyXP .error-icon{fill:#552222;}#mermaid-svg-muvN6eOMXA4rCyXP .error-text{fill:#552222;stroke:#552222;}#merm…

中国科技术语杂志中国科技术语杂志社中国科技术语编辑部2025年第3期目录

理论研究 认知术语学与社会认知术语学比较研究 吴小芳; 3-11 大语言模型背景下的术语翻译研究&#xff1a;现状、问题与展望 朱玉彬;王梓; 12-20 航空事件谣言叙事中的术语初探 刘成盼;刘东亮; 21-28 定名研讨 浅谈训诂、训诂学和训诂学术语 林童; 29-35 …

自然语言处理NLP期末复习

目录 第一章1. NLP的基本过程包括哪些-自然语言处理面临的困难是什么2. 自然语言处理算法定义&#xff0c;过程和应用3. 结合自己的研究-描述研究中涉及的自然语言处理模型或算法&#xff0c;模型或算法原理&#xff0c;具体的处理过程4. 自然语言处理的的两大核心任务是5. 程序…

单片机 - STM32F103“复用功能重映射”完整解析:从JTAG释放到TIM重映射实战详解

本文将详细讲解 STM32F103 系列中常见的“复用功能重映射”&#xff08;Remap&#xff09;机制&#xff0c;包括 JTAG 占用、引脚默认功能与复用功能的关系&#xff0c;以及如何通过寄存器或标准库代码实现重映射。以 TIM3 在 PB4/PB5 上输出 PWM 为例&#xff0c;进行实战讲解…