springboot-Redis工具類&對象與字符串互轉&響應結果類

一、Redis工具類

/**
 * 功能描述:redis工具類
 */
@Component
public class RedisClient {


    @Autowired
    private StringRedisTemplate redisTpl; //jdbcTemplate

    /**
     * 功能描述:設置key-value到redis中
     *
     * @param key
     * @param value
     * @return
     */
    public boolean set(String key, String value) {
        try {
            redisTpl.opsForValue().set(key, value);
            return true;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }

    }

    /**
     * 功能描述:通過key獲取緩存裏面的值
     *
     * @param key
     * @return
     */
    public String get(String key) {
        return redisTpl.opsForValue().get(key);
    }

    @Autowired
    private StringRedisTemplate redisTemplate;


   /* *//**
     * 通過字符串key獲取值
     *
     * @param key 鍵
     * @return 值
     *//*
    public String get(String key) {
        return key == null ? null : redisTemplate.opsForValue().get(key);
    }


    *//**
     * 普通緩存放入
     *
     * @param key   鍵
     * @param value 值
     * @return true成功 false失敗
     *//*
    public boolean set(String key, String value) {
        try {
            redisTemplate.opsForValue().set(key, value);
            return true;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }

    }*/


    /**
     * 功能描述:設置某個key過期時間
     *
     * @param key
     * @param time
     * @return
     */
    public boolean expire(String key, long time) {
        try {
            if (time > 0) {
                redisTemplate.expire(key, time, TimeUnit.SECONDS);
            }
            return true;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }


    /**
     * 功能描述:根據key 獲取過期時間
     *
     * @param key
     * @return
     */
    public long getExpire(String key) {
        return redisTemplate.getExpire(key, TimeUnit.SECONDS);
    }


    /**
     * 遞增
     *
     * @param key 鍵
     * @return
     */
    public long incr(String key, long delta) {
        return redisTemplate.opsForValue().increment(key, delta);
    }

    /**
     * 遞減
     *
     * @param key   鍵
     * @param delta 要減少幾
     * @return
     */
    public long decr(String key, long delta) {
        return redisTemplate.opsForValue().increment(key, -delta);
    }

}

二、敏捷開發redis—對象與字符串互轉

public class JsonUtils {
    private static ObjectMapper objectMapper = new ObjectMapper();
    //對象轉字符串
    public static <T> String obj2String(T obj){
        if (obj == null){
            return null;
        }
        try {
            return obj instanceof String ? (String) obj : objectMapper.writeValueAsString(obj);
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
    //字符串轉對象
    public static <T> T string2Obj(String str,Class<T> clazz){
        if (StringUtils.isEmpty(str) || clazz == null){
            return null;
        }
        try {
            return clazz.equals(String.class)? (T) str :objectMapper.readValue(str,clazz);
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
}

附:springboot:數據庫連接配置 和 redis基礎配置

#=========mybatis與數據庫 基礎配置=========
#別名
mybatis.type-aliases-package=com.sys.springboot04.domain
#驅動配置可省略,springboot可以自動識別
spring.datasource.driver-class-name =com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/數據庫名稱?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
spring.datasource.username =root
spring.datasource.password =root
#如果不配置阿里的druid,會自動使用默認的數據源 (com.zaxxer.hikari.HikariDataSource)
spring.datasource.type = com.alibaba.druid.pool.DruidDataSource
#控制檯顯示SQL
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl 



#=========redis基礎配置=========
spring.redis.database=0
spring.redis.host=127.0.0.1
spring.redis.port=6379
#連接池中的最小空閒連接,默認值是0。
spring.redis.jedis.pool.min-idle=10
# 連接池中的最大空閒連接,默認值是8。
spring.redis.jedis.pool.max-idle=50
#=========redis線程池設置=========
# 等待可用連接的最大時間,單位毫秒,默認值爲-1,表示永不超時
spring.redis.jedis.pool.max-wait=1000

注:如果引入MySQL驅動後,連接數據庫報錯原因:數據庫版本與jdbc版本不一致導致;解決方案:加上版本號<version>5.1.45</version>

在這裏插入圖片描述

三、響應結果類
springboot:響應結果後,把數據轉爲 json 數據

/**
 * 響應結果類
 */
public class JsonData implements Serializable {


	private Integer code; // 狀態碼 0 表示成功,1表示處理中,-1表示失敗
	private Object data; // 數據
	private String msg;// 描述

	public JsonData() {
	}

	public JsonData(Integer code, Object data, String msg) {
		this.code = code;
		this.data = data;
		this.msg = msg;
	}

	// 成功,傳入數據
	public static JsonData buildSuccess() {
		return new JsonData(0, null, null);
	}

	// 成功,傳入數據
	public static JsonData buildSuccess(Object data) {
		return new JsonData(0, data, null);
	}

	// 失敗,傳入描述信息
	public static JsonData buildError(String msg) {
		return new JsonData(-1, null, msg);
	}

	// 失敗,傳入描述信息,狀態碼
	public static JsonData buildError(String msg, Integer code) {
		return new JsonData(code, null, msg);
	}

	// 成功,傳入數據,及描述信息
	public static JsonData buildSuccess(Object data, String msg) {
		return new JsonData(0, data, msg);
	}

	// 成功,傳入數據,及狀態碼
	public static JsonData buildSuccess(Object data, int code) {
		return new JsonData(code, data, null);
	}

	public Integer getCode() {
		return code;
	}

	public void setCode(Integer code) {
		this.code = code;
	}

	public Object getData() {
		return data;
	}

	public void setData(Object data) {
		this.data = data;
	}

	public String getMsg() {
		return msg;
	}

	public void setMsg(String msg) {
		this.msg = msg;
	}

	@Override
	public String toString() {
		return "JsonData [code=" + code + ", data=" + data + ", msg=" + msg
				+ "]";
	}

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章