免费试用

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

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文档。

至此,我们使用


相关知识:
电子商务百度小程序开发
电子商务百度小程序是一种基于百度智能小程序平台的应用程序,用于在百度移动搜索和百度APP上提供更便捷和优质的电子商务服务。它能够提供与传统网页或App相似的功能和使用体验,同时具备更低的开发成本和更高的推广效果。本文将详细介绍电子商务百度小程序的原理和开发
2023-08-23
阿里巴巴小程序怎么开发的
阿里巴巴小程序是基于阿里巴巴生态体系的一种轻量级应用程序,可以在手机端使用。它是通过阿里巴巴开放平台开发者中心提供的小程序开发工具进行开发的,这个工具是基于阿里云技术提供的一种云开发平台。阿里巴巴小程序的开发原理主要是通过一种特殊的技术实现的,这种技术被称
2023-08-09
阿拉善盟小程序开发公司
阿拉善盟小程序开发公司是指专业从事小程序开发、销售和服务的企业。小程序是一种轻量级应用程序,在微信、支付宝等平台上开发,运行于用户的移动终端上。阿拉善盟小程序开发公司的主要工作是针对客户的需求进行程序定制开发,提供完整的小程序解决方案。公司可以根据客户的需
2023-08-09
安顺餐饮连锁小程序开发
餐饮连锁店是现代社会中广泛存在的一种商业模式,这种模式优势在于可以在不同的位置开设分店,以便更多的消费者体验店铺的产品和服务。随着互联网时代的到来,餐饮连锁店不再局限于传统的实体店铺,小程序的出现为餐饮连锁店提供了全新的机会和挑战。本文将详细介绍安顺餐饮连
2023-08-09
安仁公众号小程序软件定制开发
公众号小程序是一种无需下载安装即可使用的轻量化应用,是微信公众号的重要组成部分,为用户提供了完整的服务体验。其中,安仁公众号小程序软件定制开发就是根据客户需求,按照一定的技术架构和标准,进行制定特定功能、设计UI界面、开发系统后台和接口等,并最终形成具备商
2023-08-09
php开发小程序后端开发流程
在开发小程序后端之前,需要有一个基本的理解:小程序前端采用的是基于 WebView 的渲染技术,同一页面之间只会发生部分渲染的变化,所以前端页面的渲染速度快,同时尽量减少请求,页面缓存的设计也非常重要。接下来,我们就来讲一下小程序后端开发的流程。1. 选择
2023-08-09
linux微信小程序开发工具
微信小程序是一种新的应用开发方式,它可以在微信中直接运行,而无需下载和安装。这种轻便、快速的方式让小程序开发变得更加容易。但是,如果你想在Linux系统下开发微信小程序,你需要一些特殊的工具来帮助你完成这个过程。本文将为你介绍如何在Linux系统中使用微信
2023-08-09
小程序开发工具编辑保存快捷
小程序开发工具是一款非常实用的工具,它能够辅助开发者轻松开发出高质量的小程序。其中,编辑保存是小程序开发工具中最常用也最重要的功能之一,下面我来详细介绍一下。一、编辑保存原理小程序开发工具是基于微信官方提供的开发规范和 API 进行开发的。在开发过程中,我
2023-05-26
小程序开发工具如何设置字体
随着微信小程序的兴起,小程序开发工具也得到了广泛应用。小程序开发工具是微信官方提供的一款支持小程序开发的集成开发环境(IDE),它具有方便、快捷、高效、安全等优势,方便开发者进行小程序的开发和调试。在小程序的开发过程中,我们经常需要改变字体样式来提升小程序
2023-05-26
清远哪里有微信小程序开发工具
清远市目前尚未有官方的微信小程序开发工具,但是在市内也可以通过其他途径获得开发工具和相关知识。以下是一些适用于清远市的微信小程序开发工具介绍和相关学习资源。1. 官方开发工具微信小程序官方提供了一款可在 Windows、Mac 和 Linux 操作系统上运
2023-05-26
奶茶小程序开发工具
奶茶小程序开发工具是一种专门用于开发、构建和部署奶茶小程序的集成开发环境(IDE)。通过奶茶小程序开发工具,开发人员可以轻松地完成奶茶小程序的开发和发布,从而节约时间和精力,提高开发效率和质量。奶茶小程序开发工具的特点:1.集成大量优秀的开发工具:奶茶小程
2023-05-26
百度开发工具不能编辑小程序
百度开发工具是一款方便开发者开发、调试、编辑小程序的工具,但是,这个工具却不能编辑小程序,这是因为百度开发工具与小程序的运行原理有关。小程序是一种由微信平台提供的允许用户在不需下载应用的情况下使用应用功能的新型服务。小程序的运行方式是通过将小程序源代码上传
2023-05-22