当前位置: 首页 > news >正文

创建一个Java Web API项目

创建一个Java Web API涉及多个步骤和技术栈,包括项目设置、依赖管理、数据访问层实现、业务逻辑实现、控制层开发以及测试和部署。在这篇详解中,我将带领你通过一个完整的Java Web API实现流程,采用Spring Boot和MyBatis-Plus作为主要技术工具。

在这里插入图片描述

一、项目初始化

在这里插入图片描述

  1. 选择技术栈:首先,需要确定使用Spring Boot作为框架,MyBatis-Plus作为ORM框架,Spring Web作为Rest接口的实现工具。

  2. 创建Maven项目:采用Maven进行依赖管理,Spring Initializr是一个很好的工具,可以快速生成基本的Spring Boot项目结构。

  3. 设置pom.xml文件

    <dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.6.4</version><type>pom</type><scope>import</scope></dependency></dependencies>
    </dependencyManagement><dependencies><!-- Spring Boot Starter Web for building web, including RESTful applications --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- MyBatis-Plus for data access layer --><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3.4</version></dependency><!-- MySQL driver --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency><!-- Other necessary dependencies -->...
    </dependencies>
    

二、项目目录结构

在这里插入图片描述

通常的Spring Boot项目目录结构如下:

src
└── main├── java│   └── com│       └── example│           ├── controller│           ├── service│           ├── serviceImpl│           ├── mapper│           ├── entity│           └── dto└── resources├── static├── templates└── application.yml

三、配置文件

在这里插入图片描述

application.yml文件用于配置数据库连接和MyBatis-Plus设置:

spring:datasource:url: jdbc:mysql://localhost:3306/yourdbusername: rootpassword: passworddriver-class-name: com.mysql.cj.jdbc.Drivermybatis-plus:mapper-locations: classpath:/mapper/*Mapper.xmltype-aliases-package: com.example.entity

四、实体层

在这里插入图片描述

创建实体类,如User

package com.example.entity;import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;@TableName("user")
public class User {@TableIdprivate Long id;private String name;private Integer age;// Getters and Setters
}

五、数据访问层

实现数据访问层接口:

package com.example.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.entity.User;
import org.apache.ibatis.annotations.Mapper;@Mapper
public interface UserMapper extends BaseMapper<User> {
}

六、服务层

在这里插入图片描述

编写服务接口和实现类:

package com.example.service;import com.example.entity.User;
import java.util.List;public interface UserService {List<User> getAllUsers();User getUserById(Long id);void createUser(User user);void updateUser(User user);void deleteUser(Long id);
}
package com.example.serviceImpl;import com.example.entity.User;
import com.example.mapper.UserMapper;
import com.example.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.List;@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserMapper userMapper;@Overridepublic List<User> getAllUsers() {return userMapper.selectList(null);}@Overridepublic User getUserById(Long id) {return userMapper.selectById(id);}@Overridepublic void createUser(User user) {userMapper.insert(user);}@Overridepublic void updateUser(User user) {userMapper.updateById(user);}@Overridepublic void deleteUser(Long id) {userMapper.deleteById(id);}
}

七、控制层

创建RESTful接口:

package com.example.controller;import com.example.entity.User;
import com.example.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;import java.util.List;@RestController
@RequestMapping("/api/users")
public class UserController {@Autowiredprivate UserService userService;@GetMappingpublic List<User> getAllUsers() {return userService.getAllUsers();}@GetMapping("/{id}")public User getUserById(@PathVariable Long id) {return userService.getUserById(id);}@PostMappingpublic void createUser(@RequestBody User user) {userService.createUser(user);}@PutMappingpublic void updateUser(@RequestBody User user) {userService.updateUser(user);}@DeleteMapping("/{id}")public void deleteUser(@PathVariable Long id) {userService.deleteUser(id);}
}

八、测试和部署

1. 测试
  • 使用JUnit进行单元测试。
  • 使用Postman等工具进行API测试。
2. 部署
  • 生成.jar文件,通过命令java -jar <jar-file>.jar运行应用。
  • 也可以在云服务平台如AWS, Azure, 或者阿里云上进行部署。

九、MyBatis-Plus特性分析

在这里插入图片描述

MyBatis-Plus是MyBatis的一个增强工具,设计为简化开发、提高效率。以下是MyBatis-Plus的一些关键特性和配置:

  1. CRUD操作:MyBatis-Plus扩展了MyBatis的基本功能,提供自动生成的CRUD接口,开发者无需编写XML文件来实现基本的增删改查功能。

  2. 分页插件:内置分页插件,轻松实现物理分页和信息统计,减少了开发分页逻辑的复杂性。

  3. 自动填充:支持自动填充策略,帮助企业自动维护创建时间、更新时间等字段。

  4. 代码生成器:提供代码生成器,可以通过简单的配置自动生成符合业务需求的代码,快速搭建基础业务。

  5. 多种插件支持:插件机制非常灵活,如乐观锁插件、防止全表更新操作插件,满足各种复杂的业务场景。

  6. 高性能:基于MyBatis,深度优化了单表操作,兼容MyBatis所有功能。

例如,分页插件的配置使用:

@Configuration
public class MybatisPlusConfig {@Beanpublic PaginationInterceptor paginationInterceptor() {return new PaginationInterceptor();}
}

在实现统一的CRUD操作的时候,

Page<User> page = new Page<>(1, 10);
IPage<User> userIPage = userMapper.selectPage(page, null);

上述代码可以轻松实现用户数据的分页查询。

未来的改进点可以是结合Spring Cloud进行整个系统微服务化,实现更大的扩展性和灵活性。

总结:Java Web API实现结合Spring Boot和MyBatis-Plus可以大大简化开发中的数据访问复杂性,优化开发流程并增强系统的可维护性。理解并合理运用MyBatis-Plus中的各种特性,更能使开发事半功倍。

//python 因为爱,所以学
print("Hello, Python!")

关注我,不迷路,共学习,同进步

关注我,不迷路,共学习,同进步

http://www.lryc.cn/news/453677.html

相关文章:

  • 对称加密算法的使用Java和C#
  • 10款好用的开源 HarmonyOS 工具库
  • ubuntu22.04中备份Iptables的设置
  • (PyTorch) 深度学习框架-介绍篇
  • 若依从redis中获取用户列表
  • 文件上传之%00截断(00截断)以及pikachu靶场
  • Chainlit集成LlamaIndex并使用通义千问实现和数据库交互的网页对话应用(text2sql)
  • 计组复习笔记
  • 62. 环境贴图2
  • MATLAB中数据导入与导出的全面指南
  • Jenkins从入门到精通,构建高效自动化流程
  • 【Android 13源码分析】Activity生命周期之onCreate,onStart,onResume-2
  • 如何在电脑上浏览手机界面
  • 国产RISC-V案例分享,基于全志T113-i异构多核平台!
  • Day(16)--File
  • Axios入门使用
  • 大数据实时数仓Hologres(四):基于Flink+Hologres搭建实时数仓
  • 关于HTML 案例_个人简历展示02
  • Windows 11 24H2 v26100.1742 官方简体中文版
  • 【AIGC半月报】AIGC大模型启元:2024.10(上)
  • Codeforces Beta Round 14 (Div. 2) E. Camels (DP)
  • CSID-GAN:基于生成对抗网络的定制风格室内平面设计框架论文阅读
  • 02SQLite
  • 学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
  • JDBC编程
  • Python : 类变量、静态方法、类方法
  • 大厂笔试现已经禁用本地IDE怎么看
  • 【PostgreSQL】入门篇——如何创建、删除和管理数据库及其用户,包括权限设置和角色管理
  • 网络安全:保护数字时代的堡垒
  • 【rCore OS 开源操作系统】Rust 字符串(可变字符串String与字符串切片str)