
掌握API建模:基本概念和實踐
之后我們看下Redis的方法,畢竟調用第三方都是看看然后根據自己需要裹一下。
也是先要初始化配置信息,然后創建實體對象,調用方法,這里說明下,默認的value值是byte[],當然官方也有擴展方法。
好了,看完了方法,我們來開始Util吧。
首先,我們還是要先做配置信息,前面已經在appsettings寫過配置信息,這里直接在AprilConfig中添加上。
private static string _IsOpenCache = string.Empty;
/// <summary>
/// 是否使用Redis
/// </summary>
public static bool IsOpenCache
{
get
{
if (string.IsNullOrEmpty(_IsOpenCache))
{
_IsOpenCache = Configuration["Redis:IsOpenRedis"];
}
if (_IsOpenCache.ToLower() == "true")
{
return true;
}
return false;
}
}
private static string _RedisConnectionString = string.Empty;
/// <summary>
/// Redis默認連接串
/// </summary>
public static string RedisConnectionString
{
get{
if (string.IsNullOrEmpty(_RedisConnectionString))
{
_RedisConnectionString = Configuration["Redis:ConnectionString"];
}
return _RedisConnectionString;
}
}
配置信息設置完成之后,開始初始化Redis的方法。
private static RedisCache _redisCache = null;
private static RedisCacheOptions options = null;
/// <summary>
/// 初始化Redis
/// </summary>
public static void InitRedis()
{
if (AprilConfig.IsOpenCache)
{
_redisCache = new RedisCache(GetOptions());
}
}
/// <summary>
/// 獲取配置項信息
/// </summary>
/// <returns></returns>
protected static RedisCacheOptions GetOptions()
{
options = new RedisCacheOptions();
options.Configuration = AprilConfig.RedisConnectionString;
options.InstanceName = "April.Redis";
return options;
}
/// <summary>
/// 添加數據
/// </summary>
/// <param name="key">鍵</param>
/// <param name="value">值</param>
/// <param name="ExprireTime">過期時間</param>
public static void Add(string key, object value, int ExprireTime = 10)
{
if (string.IsNullOrEmpty(key))
{
return;
}
string strValue = string.Empty;
try
{
strValue = JsonConvert.SerializeObject(value);
}
catch (Exception ex)
{
LogUtil.Error($"Redis.Add轉換失敗:{ex.Message}");
}
if (!string.IsNullOrEmpty(strValue))
{
_redisCache.SetString(key, strValue, new Microsoft.Extensions.Caching.Distributed.DistributedCacheEntryOptions()
{
AbsoluteExpiration = DateTime.Now.AddMinutes(ExprireTime)
});
}
}
/// <summary>
/// 獲取數據(對象)
/// </summary>
/// <typeparam name="T">對象類型</typeparam>
/// <param name="key">鍵</param>
/// <returns></returns>
public static T Get<T>(string key)
{
string value = Get(key);
if (string.IsNullOrEmpty(value))
{
return default(T);
}
T obj = default(T);
try
{
obj = JsonConvert.DeserializeObject<T>(value);
}
catch (Exception ex)
{
LogUtil.Error($"Redis.Get轉換失敗:{ex.Message},數據:{value}");
}
return obj;
}
/// <summary>
/// 移除數據
///</summary>
/// <param name="key">鍵</param>
public static void Remove(string key)
{
if (!string.IsNullOrEmpty(key))
{
_redisCache.Remove(key);
}
}
/// <summary>
/// 重置數據
/// </summary>
/// <param name="key">鍵</param>
/// <param name="value">值</param>
/// <param name="expireTime">過期時間</param>
public static void Replace(string key, object value, int expireTime = 10)
{
if (!string.IsNullOrEmpty(key))
{
Remove(key);
Add(key, value, expireTime);
}
}
具體使用的方法,這里不多寫了代碼地址:
https://github.com/AprilBlank/April.WebApi,感覺代碼貼的多了,自己也習慣了復制粘貼,看一個封裝好的方法,就要去看他的源碼(如果只是用的話就算了),這樣對方法的使用以及自身的業務需要封裝會有很好的幫助,畢竟會用是第一步,會改是第二步,封裝是第三步,自己寫那就是最終級了(這句純屬自勉)。
好了,寫完之后,習慣來一遍測試,不想自己整理的東西最終還是不能用,千篇一律不可怕,可怕的是不知道最終的效果。
ps:說是覆蓋,其實就是刪除然后新增-,-|||
寫到這里基本上都結束了,簡單的說明了Redis的使用,后續還是會不斷更新,比如那么多database,如果隨意切換,redis存儲之后會不會有什么其他問題等等,學以致用,用方知錯,錯而能改,改了就行。
文章轉自微信公眾號@DotNet