Spring Boot:从入门到实践的全面指南(2)

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 2.5 在Spring Boot中使用JSP尽管Spring Boot推荐使用Thymeleaf作为其模板引擎,但在某些情况下,我们可能仍然需要在Spring Boot应用中使用JSP。在这一节中,我们将详细介绍如何在Spring Boot中配置和使用JSP。

2.5 在Spring Boot中使用JSP

尽管Spring Boot推荐使用Thymeleaf作为其模板引擎,但在某些情况下,我们可能仍然需要在Spring Boot应用中使用JSP。在这一节中,我们将详细介绍如何在Spring Boot中配置和使用JSP。

2.5.1 添加依赖

要在Spring Boot中使用JSP,我们首先需要在pom.xml中添加相关的依赖。由于Spring Boot的默认内嵌容器(Embedded Tomcat)并不支持JSP,我们还需要添加tomcat-embed-jasper依赖来提供JSP的支持:

<dependencies>
    <!-- 其他依赖 -->
    <!-- 添加JSP支持 -->
    <dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-jasper</artifactId>
        <scope>provided</scope>
    </dependency>
    <!-- 添加JSTL支持 -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
    </dependency>
</dependencies>

2.5.2 配置视图解析器

接下来,我们需要在application.properties中配置Spring MVC的视图解析器,以便它能正确地找到和渲染JSP页面:

spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp

在上面的配置中,spring.mvc.view.prefixspring.mvc.view.suffix定义了JSP页面的位置和扩展名。例如,如果一个视图的名字是home,那么Spring MVC会尝试渲染/WEB-INF/jsp/home.jsp这个JSP页面。

2.5.3 创建JSP页面

现在,我们可以在src/main/webapp/WEB-INF/jsp/目录下创建JSP页面。例如,我们可以创建一个home.jsp页面:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<title>Home</title>
</head>
<body>
<h1>Welcome to Spring Boot!</h1>
</body>
</html>

2.5.4 控制器中返回视图名称

最后,我们可以在控制器中返回JSP页面的名称。Spring MVC会自动使用配置的视图解析器来找到和渲染这个JSP页面:

@Controller
public class HomeController {
    @RequestMapping("/")
    public String home() {
        return "home";
    }
}

在上面的代码中,home方法返回了"home"这个视图名称,Spring MVC会渲染/WEB-INF/jsp/home.jsp这个JSP页面。


至此,我们已经完成了在Spring Boot中使用JSP的所有配置。在下一节中,我们将介绍Spring Boot框架Web开发的相关内容。

3.1 集成MyBatis:在Spring Boot中使用MyBatis

MyBatis是一款优秀的持久层框架,支持自定义SQL、存储过程以及高级映射。Spring Boot能够与MyBatis完美地集成在一起,下面将简单介绍一下步骤:

  1. pom.xml文件中添加mybatis-spring-boot-starter依赖:
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.4</version>
</dependency>
  1. application.properties文件中配置MyBatis和数据库相关属性:
spring.datasource.url=jdbc:mysql://localhost:3306/test?useSSL=false
spring.datasource.username=root
spring.datasource.password=root
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=com.example.demo.entity

这些配置中,spring.datasource.*是数据源相关的配置,mybatis.mapper-locations是mapper映射文件的位置,mybatis.type-aliases-package是实体类所在的包。

  1. 创建对应的Mapper接口:
@Mapper
public interface UserMapper {
    User selectUser(Integer id);
}

在Mapper接口中定义你需要执行的操作,比如这里我们定义了一个selectUser方法用于查询用户。

  1. 创建对应的Mapper映射文件:
<mapper namespace="com.example.demo.mapper.UserMapper">
    <select id="selectUser" resultType="User">
        SELECT * FROM user WHERE id = #{id}
    </select>
</mapper>

在映射文件中编写具体的SQL语句。这里的namespace应与Mapper接口的全类名相对应,id应与Mapper接口中的方法名相对应。

  1. 在服务类或控制器中注入Mapper接口并使用:
@Autowired
private UserMapper userMapper;
public User getUser(Integer id) {
    return userMapper.selectUser(id);
}

至此,你就完成了Spring Boot与MyBatis的集成。现在你可以在应用中通过MyBatis进行数据的持久化操作了。

3.2 DAO开发策略:探索DAO的多种开发方式

在实际的Spring Boot项目开发中,我们除了可以使用上述的MyBatis作为数据持久层框架外,还可以使用其他一些方式来进行数据库操作,例如使用JPA(Java Persistence API)或者使用Spring Data JPA等。


下面简要介绍一下这两种方式:JPA是Java Persistence API的简称,是Java EE和Java SE环境中的持久层技术标准。其主要作用就是简化持久层的开发,让开发者用面向对象的思维来操作数据库。


在Spring Boot中使用JPA,主要是以下几个步骤:

  • 在pom.xml中添加依赖:
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
  • 配置application.properties:
spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=root
spring.jpa.hibernate.ddl-auto=update
  • 创建实体类,并使用JPA注解进行配置:
@Entity
public class User {
    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    private Integer id;
    private String name;
    // getter and setter...
}
  • 创建Repository接口,继承JpaRepository:
public interface UserRepository extends JpaRepository<User, Integer> {
}
  • 在需要的地方,注入UserRepository使用:
@Autowired
private UserRepository userRepository;

2. 使用Spring Data JPA

Spring Data JPA是在JPA的基础上进行了一定的封装,提供了一整套的数据访问层解决方案,能大大简化数据访问层的开发。

在Spring Boot中使用Spring Data JPA,主要步骤与使用JPA基本一致,不同的是在创建Repository接口时,可以定义一些复杂的查询方法:

public interface UserRepository extends JpaRepository<User, Integer> {
    List<User> findByName(String name);
    User findByNameAndId(String name, Integer id);
}

在Spring Data JPA中,你只需要按照一定的命名规则来定义方法,无需编写实现,Spring Data JPA会自动帮你完成方法的实现。

以上就是Spring Boot中DAO的其他开发方式。具体使用哪种方式,需要根据项目的实际需求来决定。

3.3 事务支持:理解Spring Boot的事务处理方式

在数据库操作中,事务是一种非常重要的机制,它可以保证一系列数据库操作要么全部成功,要么全部失败,从而保证数据的一致性。Spring Boot也提供了对事务的支持。

在Spring Boot中,可以通过使用@Transactional注解来声明一个方法或者类需要被事务管理。当标记在类上时,表示类中所有的public方法都会被事务管理。例如,我们在UserService类中的updateUser方法上添加@Transactional注解:

@Service
public class UserService {
    @Autowired
    private UserRepository userRepository;
    @Transactional
    public void updateUser(Integer id, String name) {
        User user = userRepository.findById(id).orElseThrow(() -> new RuntimeException("User not found"));
        user.setName(name);
        userRepository.save(user);
    }
}

在上述代码中,updateUser方法会被Spring的事务管理器管理,如果在方法执行过程中发生了任何未捕获的异常,那么Spring的事务管理器会自动将事务进行回滚,也就是说,这个方法中的所有数据库操作都不会被实际执行。


另外,@Transactional注解也提供了一些属性来进行更细粒度的控制,例如:


isolation:用来设置事务的隔离级别,如读已提交(READ_COMMITTED)、可重复读(REPEATABLE_READ)、串行化(SERIALIZABLE)等。


propagation:用来设置事务的传播行为,如支持当前事务(SUPPORTS)、创建新事务(REQUIRES_NEW)、嵌套事务(NESTED)等。


readOnly:设置事务是否只读。当事务只读时,数据库可以进行一些优化。


timeout:设置事务的超时时间。


rollbackFor和noRollbackFor:用来设置哪些异常会触发事务回滚。

例如:

@Transactional(isolation = Isolation.REPEATABLE_READ, 
              propagation = Propagation.REQUIRED, 
              readOnly = false, 
              timeout = 3, 
              rollbackFor = RuntimeException.class)

以上就是Spring Boot对事务支持的基本介绍,事务管理是保证数据一致性的重要手段,在进行数据库操作时,适当的使用事务管理是非常有必要的。


3.4 注解式Spring MVC:Spring MVC在Spring Boot中的应用

Spring MVC是一种基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过分离模型(Model),视图(View)和控制器(Controller)的方式,简化了Web开发。在Spring Boot环境下,Spring MVC可以更方便的进行配置和使用。


3.4.1 控制器(Controller)

在Spring MVC中,控制器是处理用户请求的核心部分。在Spring Boot环境下,我们可以通过添加@Controller或者@RestController注解来声明一个控制器类,然后在类中定义处理请求的方法。


@Controller和@RestController这两个注解的区别在于,@Controller通常用于返回一个视图,而@RestController通常用于返回一个对象作为HTTP响应体。

例如,下面这个类定义了一个简单的RESTful API,它处理GET请求,并返回一个字符串:

@RestController
public class HelloController {
    @RequestMapping("/hello")
    public String hello() {
        return "Hello, Spring Boot!";
    }
}

3.4.2 请求映射(RequestMapping)

在Spring MVC中,通过@RequestMapping注解来将一个请求映射到一个处理器方法。在Spring 4.3版本以后,也可以使用如@GetMapping、@PostMapping、@PutMapping、@DeleteMapping等注解来分别处理GET、POST、PUT、DELETE等类型的请求。

例如,下面这个类定义了一个处理POST请求的方法:

@RestController
public class UserController {
    @PostMapping("/user")
    public User createUser(@RequestBody User user) {
        // 处理创建新用户的请求
    }
}

3.4.3 参数绑定(Parameter Binding)

在处理请求的方法中,可以通过添加@PathVariable@RequestParam@RequestBody等注解来绑定请求的参数。

  • @PathVariable:用来绑定路径参数,例如/users/{id}中的id参数。
  • @RequestParam:用来绑定请求参数,例如/users?name=John中的name参数。
  • @RequestBody:用来绑定请求体,通常用于处理POST或PUT请求。

例如,下面这个方法接受一个路径参数和一个请求体:

@RestController
public class UserController {
    @PutMapping("/user/{id}")
    public User updateUser(@PathVariable Integer id, @RequestBody User user) {
        // 处理更新用户的请求
    }
}

以上就是在Spring Boot下使用Spring MVC的基本介绍,通过使用Spring MVC,我们可以更方便的开发Web应用。


3.5 实现RESTful:在Spring Boot中构建RESTful API

RESTful架构是一种设计风格,它将Web服务视为资源,并通过URI来指定,使用HTTP的动词(GET、POST、PUT、DELETE等)来描述操作。Spring Boot非常适合创建满足RESTful风格的Web服务。

接下来,我们将通过一个简单的用户管理系统,来展示如何在Spring Boot中实现RESTful服务。

3.5.1 创建User实体

首先,我们创建一个User实体类:

public class User {
    private Integer id;
    private String name;
    private String email;
    // getters and setters...
}

3.5.2 创建UserController

然后,我们创建一个UserController类,该类将处理有关用户的所有HTTP请求:

@RestController
@RequestMapping("/users")
public class UserController {
    private List<User> users = new ArrayList<>(); // 模拟数据库
    @GetMapping
    public List<User> getAllUsers() {
        return users;
    }
    @GetMapping("/{id}")
    public User getUser(@PathVariable Integer id) {
        return users.stream()
            .filter(user -> user.getId().equals(id))
            .findFirst()
            .orElse(null);
    }
    @PostMapping
    public User createUser(@RequestBody User user) {
        users.add(user);
        return user;
    }
    @PutMapping("/{id}")
    public User updateUser(@PathVariable Integer id, @RequestBody User newUser) {
        users.stream()
            .filter(user -> user.getId().equals(id))
            .findFirst()
            .ifPresent(user -> {
                users.remove(user);
                users.add(newUser);
            });
        return newUser;
    }
    @DeleteMapping("/{id}")
    public void deleteUser(@PathVariable Integer id) {
        users.removeIf(user -> user.getId().equals(id));
    }
}

在这个例子中,我们定义了以下几个RESTful API:


获取所有用户:GET /users

获取一个用户:GET /users/{id}

创建一个用户:POST /users

更新一个用户:PUT /users/{id}

删除一个用户:DELETE /users/{id}

3.5.3 测试

最后,我们可以使用任何HTTP客户端(例如Postman或curl)来测试我们的RESTful服务。


以上就是在Spring Boot中实现RESTful服务的一个简单例子。通过使用Spring MVC的注解,我们可以很方便的创建满足RESTful风格的Web服务。


3.6 集成Redis:在Spring Boot中使用Redis

Redis是一个开源的使用ANSI C语言编写、遵循BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。Spring Boot对其有着非常好的支持,让我们一起来看看如何进行集成。

3.6.1 引入依赖

首先,在我们的项目的pom.xml中加入Spring Boot对Redis的支持:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

3.6.2 配置Redis

然后,在application.properties(或application.yml)中配置Redis的信息:

spring.redis.host=localhost
spring.redis.port=6379

这里我们假设Redis服务器安装在本地,端口号为默认的6379。

3.6.3 使用RedisTemplate

接下来,我们可以使用RedisTemplate对象进行Redis操作:

@Service
public class RedisService {
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;
    public void setKey(String key, Object value){
        redisTemplate.opsForValue().set(key, value);
    }
    public Object getKey(String key){
        return redisTemplate.opsForValue().get(key);
    }
    // 更多的操作...
}

RedisTemplate是Spring提供的用于操作Redis的工具类,我们可以使用它进行各种各样的Redis操作。

3.6.4 示例代码

下面是一个简单的示例,展示如何在一个controller中使用RedisService:

@RestController
public class RedisController {
    @Autowired
    private RedisService redisService;
    @GetMapping("/redis/set")
    public String set(@RequestParam("key") String key, @RequestParam("value") String value){
        redisService.setKey(key, value);
        return "Success";
    }
    @GetMapping("/redis/get")
    public String get(@RequestParam("key") String key){
        return String.valueOf(redisService.getKey(key));
    }
}

在这个例子中,我们定义了两个接口,一个用于设置键值对,另一个用于获取指定键的值。

以上就是在Spring Boot中集成Redis的基本步骤。实际上,Spring还提供了其他更强大的功能,例如Redis的序列化和反序列化、事务支持等,你可以根据实际需求进行探索和学习。

相关文章
|
2月前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段四:学术分析 AI 项目 RAG 落地指南:基于 Spring AI 的本地与阿里云知识库实践
本文介绍RAG(检索增强生成)技术,结合Spring AI与本地及云知识库实现学术分析AI应用,利用阿里云Qwen-Plus模型提升回答准确性与可信度。
939 90
AI 超级智能体全栈项目阶段四:学术分析 AI 项目 RAG 落地指南:基于 Spring AI 的本地与阿里云知识库实践
|
4月前
|
前端开发 Java API
利用 Spring WebFlux 技术打造高效非阻塞 API 的完整开发方案与实践技巧
本文介绍了如何使用Spring WebFlux构建高效、可扩展的非阻塞API,涵盖响应式编程核心概念、技术方案设计及具体实现示例,适用于高并发场景下的API开发。
372 0
|
2月前
|
人工智能 监控 Java
Spring AI Alibaba实践|后台定时Agent
基于Spring AI Alibaba框架,可构建自主运行的AI Agent,突破传统Chat模式限制,支持定时任务、事件响应与人工协同,实现数据采集、分析到决策的自动化闭环,提升企业智能化效率。
Spring AI Alibaba实践|后台定时Agent
|
2月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
382 2
|
7月前
|
人工智能 Java API
Spring AI 实战|Spring AI入门之DeepSeek调用
本文介绍了Spring AI框架如何帮助Java开发者轻松集成和使用大模型API。文章从Spring AI的初探开始,探讨了其核心能力及应用场景,包括手动与自动发起请求、流式响应实现打字机效果,以及兼容不同AI服务(如DeepSeek、通义千问)的方法。同时,还详细讲解了如何在生产环境中添加监控以优化性能和成本管理。通过Spring AI,开发者可以简化大模型调用流程,降低复杂度,为企业智能应用开发提供强大支持。最后,文章展望了Spring AI在未来AI时代的重要作用,鼓励开发者积极拥抱这一技术变革。
2567 71
Spring AI 实战|Spring AI入门之DeepSeek调用
|
4月前
|
Java 应用服务中间件 开发者
Spring Boot 技术详解与应用实践
本文档旨在全面介绍 Spring Boot 这一广泛应用于现代企业级应用开发的框架。内容将涵盖 Spring Boot 的核心概念、核心特性、项目自动生成与结构解析、基础功能实现(如 RESTful API、数据访问)、配置管理以及最终的构建与部署。通过本文档,读者将能够理解 Spring Boot 如何简化 Spring 应用的初始搭建和开发过程,并掌握其基本使用方法。
341 2
|
8月前
|
JSON 前端开发 Java
深入理解 Spring Boot 中日期时间格式化:@DateTimeFormat 与 @JsonFormat 完整实践
在 Spring Boot 开发中,日期时间格式化是前后端交互的常见痛点。本文详细解析了 **@DateTimeFormat** 和 **@JsonFormat** 两个注解的用法,分别用于将前端传入的字符串解析为 Java 时间对象,以及将时间对象序列化为指定格式返回给前端。通过完整示例代码,展示了从数据接收、业务处理到结果返回的全流程,并总结了解决时区问题和全局配置的最佳实践,助你高效处理日期时间需求。
991 0
|
5月前
|
前端开发 Java API
基于 Spring Boot 3 与 React 的 Java 学生信息管理系统从入门到精通实操指南
本项目基于Spring Boot 3与React 18构建学生信息管理系统,涵盖前后端开发、容器化部署及测试监控,提供完整实操指南与源码,助你掌握Java全栈开发技能。
247 0
|
5月前
|
缓存 安全 Java
Spring 框架核心原理与实践解析
本文详解 Spring 框架核心知识,包括 IOC(容器管理对象)与 DI(容器注入依赖),以及通过注解(如 @Service、@Autowired)声明 Bean 和注入依赖的方式。阐述了 Bean 的线程安全(默认单例可能有安全问题,需业务避免共享状态或设为 prototype)、作用域(@Scope 注解,常用 singleton、prototype 等)及完整生命周期(实例化、依赖注入、初始化、销毁等步骤)。 解析了循环依赖的解决机制(三级缓存)、AOP 的概念(公共逻辑抽为切面)、底层动态代理(JDK 与 Cglib 的区别)及项目应用(如日志记录)。介绍了事务的实现(基于 AOP
179 0