您好,登錄后才能下訂單哦!
小編給大家分享一下Springboot項目中使用redis的配置方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
springboot一種全新的編程規范,其設計目的是用來簡化新Spring應用的初始搭建以及開發過程,SpringBoot也是一個服務于框架的框架,服務范圍是簡化配置文件。
pom.xml文件如下:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.lyy</groupId> <artifactId>redis-test</artifactId> <version>0.1-SNAPSHOT</version> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.1.RELEASE</version> <!--始終從倉庫中獲取--> <!--<relativePath/>--> </parent> <dependencies> <!--web應用基本環境,如mvc--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--redis包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> </dependencies> </project>
其中,spring-boot-starter-web包含springmvc。
application.yml文件如下:
server: port: 11011 servlet: context-path: /api/v1 spring: redis: # Redis數據庫索引(默認為0) database: 0 # Redis服務器地址 host: 127.0.0.1 # Redis服務器連接端口 port: 6379 # Redis服務器連接密碼(默認為空) # password: 123456
RedisConfig類如下:
package com.apollo.config; import com.fasterxml.jackson.databind.ObjectMapper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer; /** * @author :apollo * @since :Created in 2019/2/22 */ @Configuration @EnableCaching public class RedisConfig { @Autowired private ObjectMapper objectMapper; /** * 自定義springSessionDefaultRedisSerializer對象,將會替代默認的SESSION序列化對象。 * 默認是JdkSerializationRedisSerializer,缺點是需要類實現Serializable接口。 * 并且在反序列化時如果異常會拋出SerializationException異常, * 而SessionRepositoryFilter又沒有處理異常,故如果序列化異常時就會導致請求異常 */ @Bean(name = "springSessionDefaultRedisSerializer") public GenericJackson2JsonRedisSerializer getGenericJackson2JsonRedisSerializer() { return new GenericJackson2JsonRedisSerializer(); } /** * JacksonJsonRedisSerializer和GenericJackson2JsonRedisSerializer的區別: * GenericJackson2JsonRedisSerializer在json中加入@class屬性,類的全路徑包名,方便反系列化。 * JacksonJsonRedisSerializer如果存放了List則在反系列化的時候, * 如果沒指定TypeReference則會報錯java.util.LinkedHashMap cannot be cast。 */ @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(connectionFactory); // 使用Jackson2JsonRedisSerialize 替換默認序列化 Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class); jackson2JsonRedisSerializer.setObjectMapper(objectMapper); // 設置value的序列化規則和 key的序列化規則 redisTemplate.setValueSerializer(jackson2JsonRedisSerializer); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setHashKeySerializer(jackson2JsonRedisSerializer); redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer); redisTemplate.setDefaultSerializer(jackson2JsonRedisSerializer); redisTemplate.setEnableDefaultSerializer(true); redisTemplate.afterPropertiesSet(); return redisTemplate; } }
package com.apollo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; /** * @author :apollo * @since :Created in 2019/2/22 */ @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
實體類Animal如下:
package com.apollo.bean; /** * @author :apollo * @since :Created in 2019/2/22 */ public class Animal { private Integer weight; private Integer height; private String name; public Animal(Integer weight, Integer height, String name) { this.weight = weight; this.height = height; this.name = name; } ……這里是get、set方法 }
package com.apollo.common; /** * @author :apollo * @since :Created in 2019/2/22 */ public class ApiResult { public static final Integer STATUS_SUCCESS = 0; public static final Integer STATUS_FAILURE = -1; public static final String DESC_SUCCESS = "操作成功"; public static final String DESC_FAILURE = "操作失敗"; private Integer status; private String desc; private Object result; private ApiResult() {} private ApiResult(Integer status, String desc, Object result) { this.status = status; this.desc = desc; this.result = result; } //這個方法和Builder設計模式二選一即可,功能是重復的 public static ApiResult success(Object result) { return success(DESC_SUCCESS, result); } //同上 public static ApiResult success(String desc, Object result) { return new ApiResult(STATUS_SUCCESS, desc, result); } //同上 public static ApiResult failure(Integer status) { return failure(status, null); } //同上 public static ApiResult failure(Integer status, String desc) { return failure(status, desc, null); } //同上 public static ApiResult failure(Integer status, String desc, Object result) { return new ApiResult(status, desc, result); } public static Builder builder() { return new Builder(); } //靜態內部類,這里使用Builder設計模式 public static class Builder { private Integer status; private String desc; private Object result; public Builder status(Integer status) { this.status = status; return this; } public Builder desc(String desc) { this.desc = desc; return this; } public Builder result(Object result) { this.result = result; return this; } public ApiResult build() { return new ApiResult(status, desc, result); } } ……這里是get、set方法,這里的方法一定不能少,否則返回時無法將對象序列化 }
RedisController類如下:
package com.apollo.controller; import com.apollo.bean.Animal; import com.apollo.common.ApiResult; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.web.bind.annotation.*; import java.util.HashMap; import java.util.Map; /** * @author :apollo * @since :Created in 2019/2/22 */ @RestController @RequestMapping(value = "/redis") public class RedisController { @Autowired private RedisTemplate<String, Object> redisTemplate; /** * 測試向redis中添加數據 * @param id * @return */ @GetMapping(value = "/{id}") public ApiResult addData2Redis(@PathVariable("id") Integer id) { redisTemplate.opsForValue().set("first", id); redisTemplate.opsForValue().set("second", "hello world"); redisTemplate.opsForValue().set("third", new Animal(100, 200, "二狗子")); return ApiResult.builder() .status(ApiResult.STATUS_SUCCESS) .desc("添加成功") .build(); } /** * 測試從redis中獲取數據 * @return */ @GetMapping("/redis-data") public ApiResult getRedisData() { Map<String, Object> result = new HashMap<>(); result.put("first", redisTemplate.opsForValue().get("first")); result.put("second", redisTemplate.opsForValue().get("second")); result.put("third", redisTemplate.opsForValue().get("third")); return ApiResult.builder() .status(ApiResult.STATUS_SUCCESS) .desc("獲取成功") .result(result) .build(); } }
注意:這里是返回ApiResult對象,需要將返回的對象序列化,所以ApiResult中的get/set方法是必須的,否則會報錯:HttpMessageNotWritableException: No converter found for return value of type: class com.apollo.common.ApiResult,找不到ApiResult類型的轉換器。
使用postman請求http://localhost:11011/api/v1/redis/5,返回結果:
{ "status": 0, "desc": "添加成功", "result": null }
登錄到redis,使用命令dbsize查看存儲的數據量:
數據量為3,對應我們上邊程序中的3步操作。
使用postman請求http://localhost:11011/api/v1/redis/redis-data,返回結果:
{ "status": 0, "desc": "獲取成功", "result": { "third": { "weight": 100, "height": 200, "name": "二狗子" }, "first": 5, "second": "hello world" } }
與我們之前存入的數據對比,是正確的。
以上是“Springboot項目中使用redis的配置方法”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。