后端系统开发之——创建注册接口

2024-03-19 16:20

本文主要是介绍后端系统开发之——创建注册接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文地址:后端系统开发之——创建注册接口 - Pleasure的博客

下面是正文内容:

前言

这是一篇SpringBoot项目的实践篇。

主要用于介绍如何从零开始搭建某一种类型的系统。

个人认为,只要后端逻辑完善了,纵使前端页面千变万化都可以慢慢来,符合自己的审美就行。

当然我也才刚起步,不可能全部都是自己手搓(肯定会有所借鉴)。

正文

大致思路

接口的实现,一般要包括下面的几种功能:

注册,登录,获取用户详细信息,更新用户基本信息,更新用户头像,更新用户密码。

需要了解数据表中用户表的表结构(在此基础上进行搭建)

大致具体的流程:明确功能需求,阅读接口文档(明确输入输出),思路分析,开发写代码,调试正确性

接口文档,通常包括:基本信息(请求路径,请求方式,接口描述),请求参数(请求参数格式,请求参数说明),响应数据(响应数据类型,响应数据说明)

前置知识

先介绍一下前置知识——MVC(Model-View-Controller)架构。

必须掌握,不然你都不知道各个文件的作用以及对于整个项目的影响。

MVC通常用于构建用户界面和应用程序的组织结构,将应用程序分成三个核心组建:模型层(Model)、视图层(View)和控制层(Controller),每个部分都有不同的职责和功能。

以Web应用程序为例来进行解释。

控制层通常用于处理业务逻辑传递给视图层用于渲染页面,通常属于后端。

前端页面就属于视图层,负责展示模型层中的数据给用户,接收用户的操作。

模型层通常分为下面的几个类:

  • 实体类(Entity),应用程序中的基本数据对象,通常与数据库中的表与文档相对应,包含了数据的结构和属性,决定了数据结构和关系,提供了数据的访问方式。
  • 数据访问对象(DAO),用于与数据库进行交互的接口或类,负责执行数据库的CRUD(创建、读取、更新、删除)操作,并将数据库中的数据映射到实体类中。
  • 业务逻辑(Business Logic),是应用程序中处理业务规则和流程的部分,用于执行特定的业务操作,并确保数据的完整性和一致性。(核心部分)
  • 数据传输对象(DTO),用于在不同层之间传递数据的对象,它通常包含了一组数据属性和相应的访问方法。通常用于将实体类中的数据传递给视图层或控制层。

控制层通过将用户的请求转换成对模型层方法(接口)的调用来执行特定的业务操作,然后根据模型层返回的结果来决定如何响应用户的请求,并将模型处理的结果返回给视图层或者直接给用户。

控制器层和模型层的分离使得业务逻辑与用户界面的交互得以解耦,使得应用程序的不同部分可以独立开发、测试和维护。控制器层负责协调用户请求和业务逻辑的处理,而模型层负责处理具体的业务逻辑,从而实现了逻辑层和表示层的分离。

私有字段、公共getter和setter

私有字段是指类中的成员变量(属性),其访问权限仅限于类内部。。公共Getter和Setter是用于读取和修改对象的私有字段的公共方法。Getter用于获取私有字段的值,而Setter用于设置私有字段的值。主要用于封装对象的状态并提供对其访问和修改的方法。

顺便插一句:添加lombok依赖的作用,自动为实体类生成不同类型的构造函数,从而简化了Java代码编写时构造函数的麻烦。

主要组成部分

下面结合上面介绍的MVC典型架构,来解释一下SpringBoot项目中不同文件夹各自的作用。

  • controller文件夹——控制层,在使用中通常用于接收用户的HTTP请求并返回HTTP响应,需要调用相应的业务逻辑。
  • mapper文件夹——通常负责与数据库进行交互
  • pojo文件夹——通常包含表示简单Java对象的Java类,具有私有字段、公共getter和setter,以及可能的构造函数。这些类通常用于在应用程序中建模数据,并且通常用作实体类或数据传输对象。
  • service文件夹——模型层,包含具体服务的接口。
  • service文件夹下的impl——用于上层文件夹接口的具体实现。
  • utils文件夹——通常存放着一些工具类,是一些通用的、不属于业务逻辑的功能模块。用来执行一些常见的操作,比如字符串处理、日期操作、文件操作等。

user数据表——对应的字段以及属性

用户密码一般需要经过加密,数据库中记录MD5值

用户头像一般储存在第三方服务器上,数据库中记录索引值

部分代码

如果不是想具体上手实践的这一部分可以直接跳过了。结合上面提供的项目文件结构直接进行复制粘贴使用即可。

需要在pom.xml中添加lombok的依赖。

    <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>

controller文件夹下的UserController.java的内容

package org.example.controller;import org.example.pojo.Result;
import org.example.pojo.User;
import org.example.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate UserService userService;@PostMapping("register")public Result register(String username,String password){//查询用户User u = userService.findByUserName(username);if (u==null){//没有占用//注册userService.register(username,password);return Result.success();}else{//占用return Result.error("用户名已被占用");}//注册}
}

mapper文件夹下的UserMapper.java的内容

package org.example.mapper;import org.example.pojo.User;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
@Mapper
public interface UserMapper {//根据用户名查询用户@Select("select * from user where username=#{username}")User findByUserName(String username);//添加@Insert("insert into user(username,password,create_time,update_time)" +" values(#{username},#{password},now(),now())")void add(String username, String password);
}

pojo文件夹下的User.java的内容

package org.example.pojo;import lombok.Data;import java.time.LocalDateTime;
//lombok 在编译阶段,为实体类自动生成setter getter toString
//pom 文件中引入依赖 在实体类上添加注释@Data
public class User {private Integer id;//主键IDprivate String username;//用户名private String password;//密码private String nickname;//昵称private String email;//邮箱private String userPic;//用户头像地址private LocalDateTime createTime;//创建时间private LocalDateTime updateTime;//更新时间
}

Article.java的内容

package org.example.pojo;import lombok.Data;import java.time.LocalDateTime;@Data
public class Article {private Integer id;//主键IDprivate String title;//文章标题private String content;//文章内容private String coverImg;//封面图像private String state;//发布状态 已发布|草稿private Integer categoryId;//文章分类idprivate Integer createUser;//创建人IDprivate LocalDateTime createTime;//创建时间private LocalDateTime updateTime;//更新时间
}

Category.java的内容

package org.example.pojo;import lombok.Data;import java.time.LocalDateTime;@Data
public class Category {private Integer id;//主键IDprivate String categoryName;//分类名称private String categoryAlias;//分类别名private Integer createUser;//创建人IDprivate LocalDateTime createTime;//创建时间private LocalDateTime updateTime;//更新时间
}

Result.java的内容

package org.example.pojo;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;//统一响应结果
@NoArgsConstructor
@AllArgsConstructor
@Data
public class Result<T> {private Integer code;//业务状态码  0-成功  1-失败private String message;//提示信息private T data;//响应数据//快速返回操作成功响应结果(带响应数据)public static <E> Result<E> success(E data) {return new Result<>(0, "操作成功", data);}//快速返回操作成功响应结果public static Result success() {return new Result(0, "操作成功", null);}public static Result error(String message) {return new Result(1, message, null);}
}

Service文件夹下Userservice.java的内容

package org.example.service;import org.example.pojo.User;
public interface UserService {//根据用户名查询用户User findByUserName(String username);//注册void register(String username,String password);
}

UserServiceImpl的内容

package org.example.service;import org.example.pojo.User;
public interface UserService {//根据用户名查询用户User findByUserName(String username);//注册void register(String username,String password);
}

utils文件夹下Md5Util.java的内容

package org.example.service;import org.example.pojo.User;
public interface UserService {//根据用户名查询用户User findByUserName(String username);//注册void register(String username,String password);
}

SystemApplication.java的内容

package org.example;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class SystemApplication {public static void main( String[] args ) {SpringApplication.run(SystemApplication.class,args);}
}

application.yml的内容

spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/数据表名username: rootpassword: root

接口成功验证

因为缺少前端页面,所以需要用到接口检验工具。

这里推荐的软件是Apifox,功能强大且目前使用范围较广。

首先重启一下项目程序

按照下图的方式传递参数,可以看到返回的json格式符合一般接口文档的要求。

可以看到Windows本地MySQL数据库成功接收到新插入的username,password数据。

接口开发成功。

尾声

后面会针对系统需要的功能针对性的一个接口一个接口进行开发,大家点个关注跟进一下。

这篇关于后端系统开发之——创建注册接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/826579

相关文章

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

MySQL 临时表创建与使用详细说明

《MySQL临时表创建与使用详细说明》MySQL临时表是存储在内存或磁盘的临时数据表,会话结束时自动销毁,适合存储中间计算结果或临时数据集,其名称以#开头(如#TempTable),本文给大家介绍M... 目录mysql 临时表详细说明1.定义2.核心特性3.创建与使用4.典型应用场景5.生命周期管理6.注

MySQL的触发器全解析(创建、查看触发器)

《MySQL的触发器全解析(创建、查看触发器)》MySQL触发器是与表关联的存储程序,当INSERT/UPDATE/DELETE事件发生时自动执行,用于维护数据一致性、日志记录和校验,优点包括自动执行... 目录触发器的概念:创建触www.chinasem.cn发器:查看触发器:查看当前数据库的所有触发器的定