欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 八卦 > Java程序开发之Spring Boot快速入门:5分钟搭建RESTful API

Java程序开发之Spring Boot快速入门:5分钟搭建RESTful API

2025/3/14 21:12:20 来源:https://blog.csdn.net/a854517900/article/details/146215222  浏览:    关键词:Java程序开发之Spring Boot快速入门:5分钟搭建RESTful API

一、Spring Boot核心优势速览

1. 传统Spring vs Spring Boot对比

特性SpringSpring Boot
配置方式XML/Java Config自动配置
内嵌服务器需手动部署Tomcat/Jetty内置
依赖管理手动指定Starter POMs
监控需集成第三方Actuator内置
启动速度较慢秒级启动

二、5分钟极速开发实战

1. 创建项目(使用Spring Initializr)

  1. 访问 start.spring.io
  2. 选择配置:
    • Project: Maven
    • Language: Java
    • Spring Boot: 3.0.5
    • Dependencies: Spring Web, DevTools
  3. 点击Generate下载项目

2. 编写第一个REST控制器

@RestController  
@RequestMapping("/api")  
public class HelloController {  @GetMapping("/hello")  public String sayHello(@RequestParam(required = false) String name) {  return "Hello, " + (name != null ? name : "Spring Boot");  }  @PostMapping("/users")  public User createUser(@RequestBody User user) {  return userService.save(user);  }  
}  // 实体类  
public record User(Long id, String name, String email) {}  

3. 运行与测试

mvn spring-boot:run  
# 访问 http://localhost:8080/api/hello?name=CSDN  

三、自动配置与进阶功能

1. 自动装配原理图解

启动类@SpringBootApplication
@EnableAutoConfiguration
扫描META-INF/spring.factories
加载自动配置类
条件装配Bean

2. 常用Starter依赖说明

Starter功能包含技术
spring-boot-starter-webWeb开发Tomcat, Spring MVC
spring-boot-starter-data-jpa数据库操作Hibernate, HikariCP
spring-boot-starter-security安全认证Spring Security
spring-boot-starter-test单元测试JUnit, Mockito

四、数据库集成与REST API增强

1. 添加JPA与H2数据库

<!-- pom.xml -->  
<dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-data-jpa</artifactId>  
</dependency>  
<dependency>  <groupId>com.h2database</groupId>  <artifactId>h2</artifactId>  <scope>runtime</scope>  
</dependency>  

2. 定义实体与Repository

@Entity  
public class User {  @Id  @GeneratedValue  private Long id;  private String name;  private String email;  // getters/setters  
}  public interface UserRepository extends JpaRepository<User, Long> {}  

3. 编写CRUD API

@RestController  
@RequestMapping("/api/users")  
public class UserController {  private final UserRepository repository;  @GetMapping  public List<User> getAllUsers() {  return repository.findAll();  }  @GetMapping("/{id}")  public User getUserById(@PathVariable Long id) {  return repository.findById(id)  .orElseThrow(() -> new ResponseStatusException(HttpStatus.NOT_FOUND));  }  
}  

五、API文档生成(Swagger集成)

1. 添加OpenAPI依赖

<dependency>  <groupId>org.springdoc</groupId>  <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>  <version>2.1.0</version>  
</dependency>  

2. 访问文档界面

启动后访问:

  • API文档:http://localhost:8080/swagger-ui.html
  • OpenAPI定义:http://localhost:8080/v3/api-docs

六、生产级部署与监控

1. 打包与运行

mvn clean package  
java -jar target/demo-0.0.1-SNAPSHOT.jar  

2. 健康检查与监控

# 查看健康状态  
curl http://localhost:8080/actuator/health  # 查看环境配置  
curl http://localhost:8080/actuator/env  

3. Docker化部署

FROM eclipse-temurin:17-jdk-alpine  
COPY target/demo-0.0.1-SNAPSHOT.jar app.jar  
ENTRYPOINT ["java","-jar","/app.jar"]  

七、常见问题与解决方案

1. 启动失败:端口冲突

# application.properties  
server.port=8081  

2. 依赖冲突

mvn dependency:tree > deps.txt  # 分析依赖树  

3. 热部署失效

# 开启自动重启  
spring.devtools.restart.enabled=true  

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词