百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

[实战]Spring Boot入门

moboyou 2025-03-26 11:55 8 浏览


[实战]Spring Boot入门

原创 东风四十二 程序员小酒馆 2025年03月03日 20:01 江苏

以下是基于JDK 17的Spring Boot入门案例,整合Redis并实现常用功能的详细步骤


1.环境准备:JDK17、IDE、Redis安装。


2.创建Spring Boot项目,添加必要依赖。


3.配置Redis连接信息。

4.创建Redis配置类,自定义Template。

5.编写Service层,实现Redis操作。

6.编写Controller,暴露API。

7.测试功能,验证结果。

一、环境准备

1. 安装JDK 17

从Oracle或OpenJDK官网下载JDK 17,配置环境变量`JAVA_HOME`并验证安装:


java -version 

应输出JDK 17版本信息


2. 安装Redis

本地安装Redis服务(推荐使用Docker快速启动):


docker run --name my-redis -p 6379:6379 -d redis


二、创建Spring Boot项目

1. 通过Spring Initializr初始化项目

访问start.spring.io

,选择:

  • Project
  • : Maven
  • Language
  • : Java
  • Spring Boot
  • : 3.1.x
  • Dependencies
  • : Spring Web, Spring Data Redis


2. 项目结构

生成的项目包含:


src/main/java
├── com/example/demo
│   ├── DemoApplication.java      # 主启动类
│   ├── config/RedisConfig.java   # Redis配置类
│   ├── service/RedisService.java # Redis操作服务
│   └── controller/ApiController.java # REST接口

三、整合Redis

1. 配置Redis连接

在`application.properties`中添加:


spring.redis.host=localhost
spring.redis.port=6379
# 若Redis有密码则添加:
# spring.redis.password=yourpassword[6,7](@ref)


2. 自定义Redis序列化配置

创建`RedisConfig.java`,避免二进制乱码:


@Configuration
public class RedisConfig {
    @Bean
    public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate template = new RedisTemplate<>();
        template.setConnectionFactory(factory);
        // 使用JSON序列化
        template.setKeySerializer(new StringRedisSerializer());
        template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        return template;
    }
}


四、实现Redis常用功能

1. 基础CRUD服务类

@Service
public class RedisService {
    @Autowired
    private RedisTemplate redisTemplate;


    // 存储数据(带过期时间)
    public void set(String key, Object value, long timeout, TimeUnit unit) {
        redisTemplate.opsForValue().set(key, value, timeout, unit);
    }


    // 获取数据
    public Object get(String key) {
        return redisTemplate.opsForValue().get(key);
    }


    // 删除数据
    public Boolean delete(String key) {
        return redisTemplate.delete(key);
    }


    // 存储Hash类型
    public void hSet(String key, String field, Object value) {
        redisTemplate.opsForHash().put(key, field, value);
    }
}


2. 使用Spring Cache注解缓存

在主类上启用缓存:

@SpringBootApplication
@EnableCaching
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}


在Service方法上添加缓存:


@Cacheable(value = "userCache", key = "#id")
public User getUserById(Long id) {
    // 模拟数据库查询
    return userRepository.findById(id).orElse(null);
}



五、编写测试接口

@RestController
@RequestMapping("/api")
public class ApiController {
    @Autowired
    private RedisService redisService;


    @PostMapping("/set")
    public String setData(@RequestParam String key, @RequestParam String value) {
        redisService.set(key, value, 10, TimeUnit.MINUTES); // 10分钟过期
        return "数据已存储";
    }


    @GetMapping("/get")
    public Object getData(@RequestParam String key) {
        return redisService.get(key);
    }


    @DeleteMapping("/delete")
    public String deleteData(@RequestParam String key) {
        return redisService.delete(key) ? "删除成功" : "键不存在";
    }
}




六、运行与测试

1. 启动应用

mvn spring-boot:run




2. 测试接口

使用`curl`或Postman发送请求:



# 存储数据
curl -X POST "http://localhost:8080/api/set?key=name&value=SpringBoot"


# 获取数据
curl "http://localhost:8080/api/get?key=name"


# 删除数据
curl -X DELETE "http://localhost:8080/api/delete?key=name"




七、扩展功能建议

1. 连接池优化

在`application.properties`中配置Lettuce连接池参数:



spring.redis.lettuce.pool.max-active=8
spring.redis.lettuce.pool.max-idle=4




2. 缓存穿透处理

使用`@Cacheable`的`unless`条件或布隆过滤器避免频繁查询空值。



通过以上步骤,您已完成一个基于JDK 17的Spring Boot入门案例,整合了Redis的常用功能。如需进一步优化,可参考Spring Data Redis官方文档。





微信扫一扫
关注该公众号

相关推荐

php宝塔搭建部署实战服务类家政钟点工保姆网站源码

大家好啊,我是测评君,欢迎来到web测评。本期给大家带来一套php开发的服务类家政钟点工保姆网站源码,感兴趣的朋友可以自行下载学习。技术架构PHP7.2+nginx+mysql5.7+JS...

360自动收录简介及添加360自动收录功能的详细教程

以前我们都是为博客站点添加百度实时推送功能,现在360已经推出了自动收录功能,个人认为这个功能应该跟百度的实时推送功能差不多,所以我们也应该添加上这个功能,毕竟360在国内的份额还是不少的。360自动...

介绍一个渗透测试中使用的WEB扫描工具:Skipfish

Skipfish简介Skipfish是一款主动的、轻量级的Web应用程序安全侦察工具。它通过执行递归爬取和基于字典的探测来为目标站点准备交互式站点地图。该工具生成的最终报告旨在作为专业Web应用程序安...

好程序员大数据培训分享Apache-Hadoop简介

好程序员大数据培训分享Apache-Hadoop简介  好程序员大数据培训分享Apache-Hadoop简介,一、Hadoop出现的原因:现在的我们,生活在数据大爆炸的年代。国际数据公司已经预测在20...

LPL比赛数据可视化,完成这个项目,用尽了我的所有Python知识

LPL比赛数据可视化效果图完成这个项目,我感觉我已经被掏空了,我几乎用尽了我会的所有知识html+css+javascript+jQuery+python+requests+numpy+mysql+p...

网站被谷歌标记“有垃圾内容”但找不到具体页面?

谷歌的垃圾内容判定机制复杂,有时违规页面藏得深(如用户注册页、旧测试内容),或是因第三方插件漏洞被注入垃圾代码,导致站长反复排查仍毫无头绪。本文提供一套低成本、高执行性的解决方案。你将学会如何利用谷歌...

黑客必学知识点--如何轻松绕过CDN,找到真实的IP地址

信息收集(二)1、cms识别基础为什么要找CMS信息呢?因为有了CMS信息之后,会给我们很多便利,我们可以搜索相应CMS,有没有公开的漏洞利用根据敏感文件的判断:robots.txt文件robots....

Scrapy 爬虫完整案例-提升篇

1Scrapy爬虫完整案例-提升篇1.1Scrapy爬虫进阶案例一Scrapy爬虫案例:东莞阳光热线问政平台。网站地址:http://wz.sun0769.com/index.php/que...

如何写一个疯狂的爬虫!

自己在做张大妈比价(http://hizdm.com)的时候我先后写了两个版本的爬虫(php版本和python版本),虽然我试图将他们伪装的很像人但是由于京东的价格接口是一个对外开放的接口,如果访问频...

程序员简历例句—范例Java、Python、C++模板

个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...

Python爬虫高级之JS渗透登录新浪微博 | 知了独家研究

小伙伴们看到标题可能会想,我能直接自己登陆把登陆后的cookie复制下来加到自定义的请求头里面不香嘛,为什么非要用python模拟登录的过程?如果我们是长期爬取数据,比如每天早上中午和晚上定时爬取新浪...

使用Selenium实现微博爬虫:预登录、展开全文、翻页

前言想实现爬微博的自由吗?这里可以实现了!本文可以解决微博预登录、识别“展开全文”并爬取完整数据、翻页设置等问题。一、区分动态爬虫和静态爬虫1、静态网页静态网页是纯粹的HTML,没有后台数据库,不含程...

《孤注一掷》关于黑客的彩蛋,你知道多少?

电影总是能引发人们的好奇心,尤其是近日上映的电影《孤注一掷》。这部电影由宁浩监制,申奥编剧执导,是一部反诈骗犯罪片。今天给大家讲解一下影片潘生用的什么语言,以及写了哪些程序。揭秘影片中的SQL注入手法...

python爬虫实战之Headers信息校验-Cookie

一、什么是cookie上期我们了解了User-Agent,这期我们来看下如何利用Cookie进行用户模拟登录从而进行网站数据的爬取。首先让我们来了解下什么是Cookie:Cookie指某些网站为了辨别...

「2022 年」崔庆才 Python3 爬虫教程 - urllib 爬虫初体验

首先我们介绍一个Python库,叫做urllib,利用它我们可以实现HTTP请求的发送,而不用去关心HTTP协议本身甚至更低层的实现。我们只需要指定请求的URL、请求头、请求体等信息即...