C#操作Redis的库有很多,比如C# Redis Client就很好用,

在NuGet上搜索 ServiceStack.Redis 

安装到项目中,将会添加以下引用

ServiceStack.Redis 库为我们提供了RedisClient类,其继承了IDisposable接口,所以可用using块来代替try-catch-finally.

Redis有几种常用的数据类型:

  1.String

  2.Hash(Hash表)

  3.List(双向链表)

  4.Set(集合类型)

  5.Sorted set

RedisClient中常用的方法

方法 说明
Add 根据传入的key-value添加一条记录,当key已存在返回false
FlushAll 使所有缓存失效(清除Redis所有数据库的所有Key)
Get 根据传入的key获取一条记录的值
GetAll 根据传入的多个key获取多条记录的值
Remove 根据传入的key移除一条记录
RemoveAll 根据传入的多个key移除多条记录
Replace 根据传入的key覆盖一条记录的值,当key不存在不会添加
Set 根据传入的key修改一条记录的值,当key不存在则添加
SetAll 根据传入的多个key覆盖多条记录
Increment  
Decrement  

针对实体对象的存储,RedisClient提供了

  public bool Set<T>(string key, T value);
  public bool Set<T>(string key, T value, TimeSpan expiresIn);
  public bool Set<T>(string key, T value, DateTime expiresAt);

  public T Get<T>(string key);

泛型方法,可以方便的存储实体对象。

针对某些事务,RedisClient提供了:

方法 说明
AcquireLock 申请对一个Key加锁(期间其他对象不能访问)
CreateTransaction 创建一个事务,返回一个IRedisTransaction对象
CreateSubscription 创建一个订阅事件返回一个IRedisSubscription对象
CreatePipeline 返回一个IRedisPipeline对象

下面我们写一个简单Redis操作的帮助类 命名为RedisHelper,为SessionHelper做准备.

  其中_ip = "127.0.0.1"表示本机回传地址,_port = 6379为Redis服务端口.

  public class RedisHelper : IRedisHelper
{
private readonly string _ip = "127.0.0.1";
private readonly int _port = 6379;
private readonly string _passWord = string.Empty;
public int Expire { get; set; } public RedisHelper(int expireTime=1200)
{
Expire = expireTime;
} public RedisHelper(string ip, int port, string passWord, int expireTime=1200)
{
_ip = ip;
_port = port;
_passWord = passWord;
Expire = expireTime;
} public T GetValue<T>(string key)
{
using (var redisClient = GetRedisClient())
{
return redisClient.Get<T>(key);
}
} public bool SetValue(string key,string value)
{
using (var redisClient = GetRedisClient())
{
if (!redisClient.Set(key, value)) return false;
SetExpire(redisClient, key);
return true;
}
} public void SetValue<T>(string key,T value)
{
using (var redisClient = GetRedisClient())
{
if (redisClient.Set<T>(key, value))
SetExpire(redisClient, key);
}
} public void Delete(string key)
{
using (var redisClient = GetRedisClient())
{
redisClient.Remove(key);
}
} private RedisClient GetRedisClient()
{
return new RedisClient(_ip, _port, _passWord);
} private void SetExpire(IRedisNativeClient redisClient,string key)
{
redisClient.Expire(key, Expire);
}
}

  

有了RedisHelper 我们再来写一个管理Session的类:

    public class SessionHelper<T>:RedisHelper, ISessionHelper<T>
{
public T GetSession(string token)
{
return !string.IsNullOrEmpty(token) ? GetValue<T>(token) : default(T);
} public string CreateSession(T value)
{
var guid = Guid.NewGuid().ToString("D");
SetValue<T>(guid,value); return guid;
} public void RemoveSession(string token)
{
Delete(token);
}
}

至此 我们在Controller中写一个Login方法来测试一下。

   public ActionResult Login()
{
//登录逻辑
var userLoginInfo = new UserSession
{
Id = ,
Name = "Test",
Permissions = new List<string>{"Home.page"}
}; var token = _sessionHelper.CreateSession(userLoginInfo); var cookie = new HttpCookie("User")
{
Expires = DateTime.Now.AddMinutes(),
Value = token
}; Response.AppendCookie(cookie); return View();
}

当然 结果是成功的图就不贴了,这就是 Cookie+缓存 实现一套最基本的会话管理机制。

部分内容引用自 邹琼俊 ASP.NET Redis 开发

逆心 ServiceStack.Redis之IRedisClient < 第三篇 >

Redis实战与 Session缓存的更多相关文章

  1. ASP.NET Core 使用 Redis 和 Protobuf 进行 Session 缓存

    前言 上篇博文介绍了怎么样在 asp.net core 中使用中间件,以及如何自定义中间件.项目中刚好也用到了Redis,所以本篇就介绍下怎么样在 asp.net core 中使用 Redis 进行资 ...

  2. go语言实战教程:Redis实战项目应用

    项目Redis配置 在实战项目中使用Redis功能,首先需要进行Redis配置.本实战项目中,关与Redis的配置项包含:连接类型.地址.端口.公共前缀.以上配置项被定义包含在Iris框架的redis ...

  3. redis+cookies实现session机制(解决 手机浏览器不自动回传cookies导致session不可用问题)

    昨天在手机端测试自己的项目遇到如下情况. 1.在手机上(苹果qq浏览器),登陆时存在session中的图片验证码结果,一直获取不到,考虑是cookies的问题.但是其他网站有貌似可以正常使用cooki ...

  4. Redis学习笔记~StackExchange.Redis实现分布式Session

    回到目录 对于多WEB的环境现在已经是必须的了,很难想像一台WEB服务器面对百万并发的响应,所以,我们需要多台WEB服务器集群合作,来缓解这种高并发,高吞吐的场景,而对于多WEB的场景又会有个问题出现 ...

  5. python_way day19 HTML-day5 (form表单验证,CSRF,cookie,session,缓存)

    python-way day19 1. dJango的form表单验证 2.CSRF 跨站请求伪造 3.cookie,session 4.缓存 一,django表单验证功能 1.django验证基础: ...

  6. Redis基础知识之—— 缓存应用场景

    转载原文:http://www.cnblogs.com/jinshengzhi/articles/5225718.html 一.MySql+Memcached架构的问题 Memcached采用客户端- ...

  7. C# Redis实战(二) [转]

    二.Redis服务  在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图               ...

  8. (转)国内外三个不同领域巨头分享的Redis实战经验及使用场景

    随着应用对高性能需求的增加,NoSQL逐渐在各大名企的系统架构中生根发芽.这里我们将为大家分享社交巨头新浪微博.传媒巨头Viacom及图片分享领域佼佼者Pinterest带来的Redis实践,首先我们 ...

  9. C# Redis实战

    转自  :http://blog.csdn.net/qiujialongjjj/article/details/16945569 一.初步准备 Redis 是一个开源的使用ANSI C 语言编写.支持 ...

随机推荐

  1. html <select> 用JS控制默认选中项

    <html> <head> <!--禁止页面缓存--><meta http-equiv="content-type" content=&q ...

  2. 漂亮的PHP验证码

    <?php class Imagecode{ private $width ; private $height; private $counts; private $distrubcode; p ...

  3. js原生设计模式——7原型模式之真正的原型模式——对象复制封装

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  4. Struts2的拦截器----Dog实例

    拦截器是一个类,这个类包含方法,用来解决DRY规则,即代码复用的问题.如果不调用拦截器,代码中需要显示通过代码调用目标方法,定义了拦截器,系统就会自动执行.大部分时候,拦截器方法都是通过代理的方式调用 ...

  5. JAVA中获取当前运行的类名,方法名,行数

    JAVA中获取当前运行的类名,方法名,行数 public static String getTraceInfo(){ StringBuffer sb = new StringBuffer(); Sta ...

  6. 管理维护Replica Sets

    1.读写分离 有一些第三方的工具,提供了一些可以让数据库进行读写分离的工具.我们现在是否有一个疑问,从库要是能进行查询就更好了,这样可以分担主库的大量的查询请求. 1. 先向主库中插入一条测试数据 2 ...

  7. LazyInitializationException--由于session关闭引发的异常

    1,页面中进行person.department.departmentName的读取 2,Action 中只读取了person,事务作用在Service的方法中 3,后台会有org.hibernate ...

  8. 外部IIS/Apache/Nginx来代理FMS的http服务

    默认FMS在安装的时候,会安装Apache2.2,并监听8134端口,代理http服务器:当如也可以用外部的服务器,此时建立站点,并指向目录:C:\Program Files\Adobe\Flash ...

  9. puppet的配置清单书写

    puppet的配置清单书写 1使用数组,合并同类的 例如你想安装很多软件,如果分开来写的话,很麻烦,不简洁,这时我们可以使用数组来完成 以前我们这样来写 class packages{ package ...

  10. CodeForces 333A

    Secrets Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Submit Sta ...