免费试用

跨平台小程序在线开发工具,用做网页的技术做小程序,兼容微信、支付宝、抖音、快手、百度等主流小程序平台!

springboot开发小程序后台

Spring Boot 是一种基于 Spring 框架的轻量级应用程序框架,它可以简化 Spring 应用程序的开发过程。小程序后台是为小程序提供数据支持和业务逻辑处理的后端服务,本文将介绍如何使用 Spring Boot 开发小程序后台。

一、创建Spring Boot项目

1.1. 创建项目

使用 IDEA 创建一个 Spring Boot 项目,选择「Spring Initializr」快捷方式。然后按照向导的提示输入项目的基本信息,选择相关的依赖项,创建项目。

1.2. 添加依赖

在 pom.xml 文件中添加以下依赖项:

```

org.springframework.boot

spring-boot-starter-web

com.alibaba

fastjson

1.2.70

com.alibaba

druid-spring-boot-starter

1.2.6

mysql

mysql-connector-java

8.0.23

```

上面的依赖项包括了 Spring Boot、fastjson、Druid 和 MySQL Connector/J。

fastjson 是阿里巴巴的一个高性能 JSON 库,能够将 Java 对象转换为 JSON 格式。

在本项目中,我们选择使用 Druid 作为数据源连接池。它是阿里巴巴开源的一个 JDBC 连接池,拥有监控和防御 SQL 注入攻击等特性。

二、编写主程序启动类

@SpringBootApplication 注解表示该类是 Spring Boot 应用程序的启动入口。

```

@SpringBootApplication

public class App {

public static void main(String[] args) {

SpringApplication.run(App.class, args);

}

}

```

三、实现数据库连接

在 application.properties 文件中,添加数据库连接信息:

```

spring.datasource.url=jdbc:mysql://localhost:3306/test?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC

spring.datasource.username=root

spring.datasource.password=123456

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

spring.datasource.initial-size=1

spring.datasource.max-active=20

spring.datasource.min-idle=1

spring.datasource.max-wait=60000

spring.datasource.test-on-borrow=true

spring.datasource.test-on-return=false

spring.datasource.test-while-idle=true

spring.datasource.validation-query=SELECT 1

```

其中 url、username、password 需要做对应修改。请注意修改驱动程序类名,配置初始连接数、最大连接数等。

四、实现操作数据库的 DAO 层

在 src/main/java 目录下创建包名为 com.example.dao 的包,新建 UserDAO 接口:

```

@Mapper

@Repository

public interface UserDAO {

/**

* 根据用户ID查询用户

* @param id 用户ID

* @return 查询结果

*/

User queryById(Long id);

/**

* 查询所有用户

* @return 查询结果

*/

List queryAll();

/**

* 查询用户总数

* @return 查询结果

*/

int countAll();

/**

* 添加用户

* @param user 用户对象

* @return 返回添加结果

*/

int addUser(User user);

/**

* 修改用户信息

* @param user 用户对象

* @return 返回修改结果

*/

int modifyUser(User user);

/**

* 删除用户

* @param id 用户ID

* @return 返回删除结果

*/

int deleteUser(Long id);

}

```

注解 @Mapper 表示这是一个 Mybatis 的 Mapper 接口。@Repository 表示是 Spring 的 bean,会先在项目启动后初始化一边 bean,使用时直接注入即可。

在 src/main/java 目录下创建包名为 com.example.entity 的包,新建 User 实体类:

```

public class User {

private Long id;

private String userName;

private String password;

private String avatarUrl;

private String gender;

private String phone;

private Date createTime;

private Date updateTime;

// getter 和 setter 略

}

```

注解 @Data 自动为 User 类添加 getter 和 setter 方法。

在 src/main/resources 目录下创建 mapper 目录,在 mapper 目录下新建 UserMapper.xml 文件。

```

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

insert into users (

user_name,

password,

avatar_url,

gender,

phone,

create_time,

update_time

) values (

#{userName,jdbcType=VARCHAR},

#{password,jdbcType=VARCHAR},

#{avatarUrl,jdbcType=VARCHAR},

#{gender,jdbcType=VARCHAR},

#{phone,jdbcType=VARCHAR},

#{createTime,jdbcType=TIMESTAMP},

#{updateTime,jdbcType=TIMESTAMP}

)

update users

set user_name = #{userName, jdbcType=VARCHAR},

password = #{password, jdbcType=VARCHAR},

avatar_url = #{avatarUrl, jdbcType=VARCHAR},

gender = #{gender, jdbcType=VARCHAR},

phone = #{phone, jdbcType=VARCHAR},

create_time = #{createTime, jdbcType=TIMESTAMP},

update_time = #{updateTime, jdbcType=TIMESTAMP}

where id = #{id, jdbcType=BIGINT}

delete from users where id = #{id, jdbcType=BIGINT}

```

通过 XML 文件,我们将 DAO 层的方法和 SQL 语句对应起来。

五、实现业务逻辑层

在 src/main/java 目录下创建包名为 com.example.service 的包。新建 UserService 接口:

```

public interface UserService {

/**

* 根据用户ID查询用户

* @param id 用户ID

* @return 查询结果

*/

User queryById(Long id);

/**

* 查询所有用户

* @return 查询结果

*/

List queryAll();

/**

* 查询用户总数

* @return 查询结果

*/

int countAll();

/**

* 添加用户

* @param user 用户对象

* @return 返回添加结果

*/

int addUser(User user);

/**

* 修改用户信息

* @param user 用户对象

* @return 返回修改结果

*/

int modifyUser(User user);

/**

* 删除用户

* @param id 用户ID

* @return 返回删除结果

*/

int deleteUser(Long id);

}

```

创建 UserServiceImpl 类实现 UserService 接口:

```

@Service

public class UserServiceImpl implements UserService {

@Autowired

private UserDAO userDAO;

@Override

public User queryById(Long id) {

return userDAO.queryById(id);

}

@Override

public List queryAll() {

return userDAO.queryAll();

}

@Override

public int countAll() {

return userDAO.countAll();

}

@Override

public int addUser(User user) {

Date now = new Date();

user.setCreateTime(now);

user.setUpdateTime(now);

return userDAO.addUser(user);

}

@Override

public int modifyUser(User user) {

user.setUpdateTime(new Date());

return userDAO.modifyUser(user);

}

@Override

public int deleteUser(Long id) {

return userDAO.deleteUser(id);

}

}

```

注解 @Service 表示该类是 Spring 的 bean。

六、实现API接口

在 src/main/java 目录下创建包名为 com.example.controller 的包,并新建 UserController 类。

```

@RestController

@RequestMapping("/users")

public class UserController {

@Autowired

private UserService userService;

@GetMapping("/queryById")

public User queryById(@RequestParam("id") Long id) {

return userService.queryById(id);

}

@PostMapping("/addUser")

public int addUser(@RequestBody User user) {

return userService.addUser(user);

}

@PostMapping("/modifyUser")

public int modifyUser(@RequestBody User user) {

return userService.modifyUser(user);

}

@DeleteMapping("/deleteUser")

public int deleteUser(@RequestParam("id") Long id) {

return userService.deleteUser(id);

}

}

```

注解 @RestController,声明该类是一个 RESTful 风格的控制器类。@RequestMapping 表示路由映射,我们的接口路径会加上 /users 前缀。

七、启动应用程序

在 App 类中添加注解 @EnableSwagger2 和 @MapperScan:

```

@SpringBootApplication

@EnableSwagger2

@MapperScan("com.example.dao")

public class App {

public static void main(String[] args) {

SpringApplication.run(App.class, args);

}

}

```

注解 @EnableSwagger2 开启 Swagger API 文档生成器。注解 @MapperScan 扫描 Mybatis 的 Mapper 接口。

在 IntelliJ IDEA 中运行应用程序,应该就能顺利在浏览器中访问 http://localhost:8080/users/queryById?id=1000,来获取 ID 为 1000 的用户信息。

八、使用 Swagger2 生成API文档

在 pom.xml 中添加如下依赖:

```

io.springfox

springfox-swagger2

2.7.0

io.springfox

springfox-swagger-ui

2.7.0

```

在 UserController 类中,添加注解即可:

```

@RestController

@RequestMapping("/users")

@Api(tags = "用户管理接口")

public class UserController {

@Autowired

private UserService userService;

@GetMapping("/queryById")

@ApiOperation(value = "根据用户ID查询用户", notes = "根据用户ID查询用户信息")

public User queryById(@RequestParam("id") Long id) {

return userService.queryById(id);

}

@PostMapping("/addUser")

@ApiOperation(value = "添加用户", notes = "添加用户信息")

public int addUser(@RequestBody User user) {

return userService.addUser(user);

}

@PostMapping("/modifyUser")

@ApiOperation(value = "修改用户信息", notes = "修改用户信息")

public int modifyUser(@RequestBody User user) {

return userService.modifyUser(user);

}

@DeleteMapping("/deleteUser")

@ApiOperation(value = "删除用户", notes = "根据用户ID删除用户信息")

public int deleteUser(@RequestParam("id") Long id) {

return userService.deleteUser(id);

}

}

```

在 main 方法上添加如下 Swagger2 的配置类:

```

import springfox.documentation.builders.ApiInfoBuilder;

import springfox.documentation.builders.PathSelectors;

import springfox.documentation.builders.RequestHandlerSelectors;

import springfox.documentation.service.ApiInfo;

import springfox.documentation.spi.DocumentationType;

import springfox.documentation.spring.web.plugins.Docket;

import springfox.documentation.swagger2.annotations.EnableSwagger2;

@Configuration

@EnableSwagger2

public class Swagger2 {

@Bean

public Docket createRestApi() {

return new Docket(DocumentationType.SWAGGER_2)

.apiInfo(apiInfo())

.select()

.apis(RequestHandlerSelectors.basePackage("com.example.controller"))

.paths(PathSelectors.any())

.build();

}

private ApiInfo apiInfo() {

return new ApiInfoBuilder()

.title("Spring Boot 实现小程序后台")

.description("小程序后台 API 文档")

.version("1.0.0")

.build();

}

}

```

启动项目访问 http://localhost:8080/swagger-ui.html 即可查看API文档。

至此,我们使用


相关知识:
百度人脸识别小程序开发
百度人脸识别小程序是基于百度云平台的人脸识别技术开发的应用程序。它通过分析和识别人脸特征,实现人脸的检测、比对和属性分析等功能。下面将详细介绍其原理和开发过程。一、原理介绍:百度人脸识别小程序的原理基于深度学习和人工智能技术。它使用卷积神经网络(Convo
2023-08-23
安顺小程序开发培训微信公众号
随着互联网的飞速发展,移动互联网已经成为了人们生活与工作中最重要的一部分。而在移动互联网中,小程序无疑成为了一种备受关注和追捧的应用形式。作为一种轻量级的小应用,小程序不需要下载和安装,可以快速、便捷地为用户提供服务。在这个日新月异的移动互联网时代,学习安
2023-08-09
安徽小程序开发价格多少
随着互联网技术的飞速发展,微信小程序已经成为了一个风口行业,越来越多的商家和企业都开始关注小程序的开发以及其对于业务和市场的影响。安徽小程序开发价格也因此成为了很多人关注的焦点。安徽小程序开发价格的主要影响因素1. 小程序的功能需求小程序的功能需求是安徽小
2023-08-09
weix小程序开发
微信小程序是一种基于微信平台的轻量级应用,用户无需下载安装即可直接使用。与传统的应用程序不同,微信小程序主要采用了“代码片段”的形式,开发者只需要编写前端代码,后端代码由微信平台提供支持。微信小程序的开发基于微信开发者工具,首先需要在微信公众平台申请小程序
2023-08-09
oa系统小程序开发
OA系统是企业管理的重要工具,它可以为企业提供人力资源、工作流程、财务管理、客户关系等方面的支持和服务。近年来,随着微信小程序的兴起,越来越多的企业开始将自己的OA系统移植到小程序平台上,以便于员工快速、便捷地进行办公。本文将介绍OA系统小程序开发的原理和
2023-08-09
laravel 开发小程序
Laravel框架是一个非常流行的PHP框架之一,它使用了现代化的开发技术和设计模式,在Web开发领域获得了很高的声誉。小程序(微信小程序)则是一种全新的移动应用模式,它允许开发人员使用简洁的编程语言和开发环境来轻松构建小程序应用程序。如果使用Larave
2023-08-09
ai智能名片小程序制作开发全教程
AI智能名片小程序是一种在微信小程序平台上运行的工具,它可以帮助用户生成一张智能名片,并由AI进行自动识别和录入信息。该应用旨在提高商务人员和创业者在社交场合中的效率,通过优化名片管理的方式,提高商务沟通的质量和效率。本文将为大家介绍AI智能名片小程序的制
2023-08-09
java打包转换成exe
在本教程中,我们将了解如何将Java应用程序打包并转换成exe文件。通过这种方式,用户无需了解Java环境细节,就可以快速轻松地运行程序。我们需要一个转换工具来帮助我们完成这个任务,本教程主要使用Launch4j来完成这个过程。### 1. 前提条件在将J
2023-05-26
java可以生成exe文件吗
Java 程序通常编译为跨平台的字节码(.class 文件),此字节码可以在任何具有 Java 虚拟机(JVM)的设备和操作系统上运行。尽管 Java 本身并不直接生成 exe 文件,但可以通过第三方工具或者使用 JDK 中的本地编译器(如 jlink 和
2023-05-26
iebook生成的exe文件
使用IEBook生成的EXE文件,是指通过IEBook这类工具将HTML网页文件或者整个网站内容打包为一个独立的、可执行的Windows程序。这种方法方便用户在离线环境下访问网站内容,同时也适用于制作教程、提供软件帮助等场景。在本篇文章中,我们将详细介绍I
2023-05-26
将web项目打包到微信小程序操作方法
微信小程序是一种轻量级的应用程序,可以直接在微信中运行,无需下载和安装,非常方便。对于一些Web项目,如果能够将其打包成微信小程序,就可以让用户在微信中访问,提高用户的使用体验。本文将详细介绍将Web项目打包成微信小程序的原理和步骤。
2023-04-06
layui转小程序
Layui是一个非常流行的前端UI框架,而小程序则是近年来非常流行的移动应用开发方式。对于许多Layui的使用者来说,如果能够将Layui转换为小程序使用,将会非常方便。本文将介绍Layui转小程序的原理和详细步骤。## 一、Layui的特点Layui是一
2023-04-06