Token的管理

代码:

RedisCommon

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using ServiceStack.Redis;
using System.Configuration;
using ServiceStack.Redis.Generic;
using Newtonsoft.Json;

namespace Rongzi.BZone.Common.Util
{
    public class RedisCommon
    {
        private static readonly Lazy<RedisCommon> _instance = new Lazy<RedisCommon>(() => new RedisCommon());
        private static readonly string redisUrl = ConfigurationManager.AppSettings["Redis_Server"];
        private static readonly string redisPort = ConfigurationManager.AppSettings["Redis_Port"];
        private RedisCommon()
        {

        }
        public static RedisCommon getInstance
        {
            get
            {
                return _instance.Value;
            }
        }

        public RedisClient getRedisClient()
        {
            return new RedisClient(redisUrl, int.Parse(redisPort));
        }

        #region string类型操作

        /// <summary>
        /// 根据key获取对应的对象T
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="key"></param>
        /// <returns></returns>
        public T GetObj<T>(string key)
        {
            T result;
            try
            {
                using (var redis = this.getRedisClient())
                {
                    result = redis.Get<T>(key);
                }
            }
            catch (Exception)
            {

                result = default(T);
            }
            return result;
        }

        /// <summary>
        /// 根据key存储T对象
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="key"></param>
        /// <param name="val"></param>
        /// <param name="dateTime"></param>
        /// <returns></returns>
        public bool SetObj<T>(string key, T val, DateTime dateTime)
        {
            bool result = false;
            try
            {
                using (var redis = this.getRedisClient())
                {
                    result = redis.Set<T>(key, val, dateTime);
                }
            }
            catch
            {

                result = false;
            }
            return result;
        }

        /// <summary>
        /// 根据key更新T
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="key"></param>
        /// <param name="t"></param>
        /// <returns></returns>
        public bool UpdateObj<T>(string key, T t)
        {
            bool result = false;
            using (var redis = this.getRedisClient())
            {
                var value = JsonConvert.SerializeObject(t);
                result = redis.Set<string>(key, value);
            }
            return result;
        }

        /// <summary>
        /// 删除对应key的value
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public bool RemoveObj(string key)
        {
            bool result = false;
            using (var redis = this.getRedisClient())
            {
                result = redis.Remove(key);
            }
            return result;
        }
        #endregion

        #region hash类型操作

        /// <summary>
        /// 从hash表获取数据
        /// </summary>
        public T Get<T>(string hashId, string key)
        {
            using (var redis = this.getRedisClient())
            {
                string value = redis.GetValueFromHash(hashId, key);
                return JsonConvert.DeserializeObject<T>(value);
            }
        }

        /// <summary>
        /// 获取整个hash的数据
        /// </summary>
        public List<T> GetAll<T>(string hashId)
        {
            using (var redis = this.getRedisClient())
            {
                var result = new List<T>();
                var list = redis.GetHashValues(hashId);
                if (list != null && list.Count > 0)
                {
                    list.ForEach(x =>
                    {
                        var value = JsonConvert.DeserializeObject<T>(x);
                        result.Add(value);
                    });
                }
                return result;
            }
        }

        /// <summary>
        /// 判断某个数据是否已经被缓存
        /// </summary>
        public bool Exist<T>(string hashId, string key)
        {
            bool result = false;
            using (var redis = this.getRedisClient())
            {
                result = redis.HashContainsEntry(hashId, key);
            }
            return result;
        }

        /// <summary>
        /// 存储数据到hash表
        /// </summary>
        public bool Set<T>(string hashId, string key, T t)
        {
            bool result = false;
            try
            {
                using (var redis = this.getRedisClient())
                {
                    var value = JsonConvert.SerializeObject(t);
                    result = redis.SetEntryInHash(hashId, key, value);
                }
            }
            catch
            {

                result = false;
            }
            return result;
        }

        /// <summary>
        /// 移除hash中的某值
        /// </summary>
        public bool Remove(string hashId, string key)
        {
            bool result = false;
            try
            {
                using (var redis = this.getRedisClient())
                {
                    result = redis.RemoveEntryFromHash(hashId, key);
                }
            }
            catch
            {
                result = false;
            }
            return result;
        }

        /// <summary>
        /// 移除整个hash
        /// </summary>
        public bool RemoveAll(string hashId)
        {
            bool result = false;
            using (var redis = this.getRedisClient())
            {
                result = redis.Remove(hashId);
            }
            return result;
        }

        /// <summary>
        /// 设置缓存过期
        /// </summary>
        public void SetExpire(string hashId, DateTime datetime)
        {
            using (var redis = this.getRedisClient())
            {
                redis.ExpireEntryAt(hashId, datetime);
            }
        }

        #endregion

        #region 保存到硬盘
        /// <summary>
        /// 保存数据DB文件到硬盘
        /// </summary>
        public void Save()
        {
            using (var redis = this.getRedisClient())
            {
                redis.Save();
            }
        }

        /// <summary>
        /// 异步保存数据DB文件到硬盘
        /// </summary>
        public void SaveAsync()
        {
            using (var redis = this.getRedisClient())
            {
                redis.SaveAsync();
            }
        }
        #endregion
    }
}

TokenManager

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;
using Rongzi.BZone.Admin.Models;
using Rongzi.BZone.Common.Util;
using System.Configuration;

namespace Rongzi.BZone.Admin.Functions
{
    public class TokenManager
    {
        /// <summary>
        /// 设置对象过期时间
        /// </summary>
        private static readonly int interval = Convert.ToInt32(ConfigurationManager.AppSettings["Redis_TimeInterval"]);

        /// <summary>
        /// 存储对象val,获取对应的token
        /// </summary>
        /// <param name="val"></param>
        /// <returns></returns>
        public static RedisOpearteResult getToken(Manage_UserInfo val)
        {
            string tokenID = Guid.NewGuid().ToString();
            RedisOpearteResult result = new RedisOpearteResult
            {
                isok = RedisCommon.getInstance.SetObj<Manage_UserInfo>(tokenID, val, DateTime.Now.AddMinutes(interval)),
                token = tokenID,
                result = JsonConvert.SerializeObject(val)
            };
            return result;
        }

        /// <summary>
        /// 根据tokenID更新用户对象
        /// </summary>
        /// <param name="tokenID"></param>
        /// <param name="val"></param>
        /// <returns></returns>
        public static RedisOpearteResult RefreshLoginTokenData(String tokenID, Manage_UserInfo val)
        {
            RedisOpearteResult result = new RedisOpearteResult
            {
                isok = RedisCommon.getInstance.SetObj<Manage_UserInfo>(tokenID, val, DateTime.Now.AddMinutes(interval)),
                token = tokenID,
                result = JsonConvert.SerializeObject(val)
            };
            return result;
        }

        /// <summary>
        /// 刷新用户token
        /// </summary>
        /// <param name="tokenID"></param>
        public static RedisOpearteResult RefreshUserToken(string tokenID)
        {
            var obj = RedisCommon.getInstance.GetObj<Manage_UserInfo>(tokenID);
            var isExist = obj != null;
            RedisOpearteResult result = new RedisOpearteResult
            {
                isok = isExist,
                token = tokenID,
                result = "Token过期"
            };
            if (isExist)
            {
                result.result = "成功延迟";
                RedisCommon.getInstance.SetObj<Manage_UserInfo>(tokenID, obj, DateTime.Now.AddMinutes(interval));
            }
            return result;
        }

        /// <summary>
        /// 退出
        /// </summary>
        /// <param name="tokenID"></param>
        /// <returns></returns>
        public static RedisOpearteResult LoginOff(string tokenID)
        {
            var obj = RedisCommon.getInstance.GetObj<Manage_UserInfo>(tokenID);
            var isExist = obj != null;
            RedisOpearteResult result = new RedisOpearteResult
            {
                isok = isExist,
                token = tokenID,
                result = "Token过期"
            };
            if (isExist)
            {
                result.result = "退出成功";
                RedisCommon.getInstance.RemoveObj(tokenID);
            }
            return result;
        }

        /// <summary>
        /// 通过token 获取用户信息
        /// </summary>
        /// <param name="token">tokenID</param>
        /// <returns></returns>
        public static bool getUserByToken(string token, out Manage_UserInfo user)
        {
            bool isok = false;
            user = null;
            if (!string.IsNullOrEmpty(token) && RedisCommon.getInstance.GetObj<Manage_UserInfo>(token)!=null)
            {
                user = RedisCommon.getInstance.GetObj<Manage_UserInfo>(token);
                isok = true;
            }
            return isok;
        }
    }
}
时间: 2024-10-10 23:06:57

Token的管理的相关文章

基于.Net Framework 4.0 Web API开发(4):ASP.NET Web APIs 基于令牌TOKEN验证的实现

概述:  ASP.NET Web API 的好用使用过的都知道,没有复杂的配置文件,一个简单的ApiController加上需要的Action就能工作.但是在使用API的时候总会遇到跨域请求的问题, 特别各种APP万花齐放的今天,对API使用者身份角色验证是不能避免的(完全开发的API不需要对使用者身份角色进行管控,可以绕过),这篇文章就来谈谈基于令牌TOKEN身份验证的实现. 问题: 对于Web API的选择性的开放,使用者无论使用AJAX,还是HttpClient对接,总要对使用者的身份角色

Spring Token安全控制组件的实现(一)

安全知识介绍 认证(authentication),  是对用户身份的确认,比如系统登录,输入的用户名密码就是要告诉系统我是我: 授权(ahthorization), 是对身份的权限控制,就像神盾局中特工一样,你虽然通过身份确认走进了神盾局大厦,但是级别不够,很多资料并没有访问权限: 在单应用项目中,尤其是作为移动端APP后台服务项目,向客户端提供的接口往往需要考虑安全问题,最常用也最简单的实现方式是用户在手机端通过输入用户名和密码(或者手机号.邮箱和验证码)登录系统,登录成功后后台返回一个带有

在ASP.NET中实现OAuth2.0(二)之打造自己的API安全策略

1.场景介绍 公司开发了一款APP产品,前期提供的api接口都是裸奔状态 举个例子:想要获取某一个用户的数据,只需要传递该用户的ID就可以拿走数据(说多了都是泪) 现在想给这些接口穿个衣服,加个壳(对客户端进行授权) 2.业务实现 > 搭建授权服务器和资源服务器 > 给App客户端发放AppId和AppSecret > 用户向App客户端提供自己的账号和密码 > App客户端将AppId.AppSecret.账号和密码提交到授权服务器 > 授权服务器通过授权,发放token和

CVE-2014-4113 Win8.1 64位利用(2014.11)

CVE-2014-4113 Win8.1 64位利用 关于漏洞成因的分析已经很多了,但是样本针对的是win8之前的利用,国外研究员Moritz Jodeit对Win8.1上的利用做了研究,并给出了思路.根据其思路,对Win8.1利用做尝试. Win8.1中调用xxxMNFindWindowFromPoint函数后,对得到的窗口对象tagWnd结构的处理代码存在差异: Win8.1从[tag+90h]获得的值会经过检查,确定其小于7才会进行下一步操作,r10+rax*8为一个内核地址,所以这是我们

微信开发学习路线

凭借大量活跃用户,微信已成为商家重要营销平台之一.商家为庞大用户群提供定制化服务的迫切需求,吸引了大量开发者/开发商投入到微信公众平台开发中.学习和掌握微信公众平台开发技术,已成为开发者淘金的另一重要选择. 在CSDN站内,拥有大量与微信开发相关的资源,包括技术博客.问题讨论.工具资源等.CSDN邀请多位微信开发专家对这些资源取其精华,按照微信开发的学习路线展示站内优质资源,从基础入门到高级开发,帮你全面掌握微信开发. 这里,我们为您推出的是微信开发的基础入门及高级进阶部分. 基础入门 认识微信

Joomla 2.5 MVC剖析

Joomla整个系统,由core, component, module, plugin组成,而component是唯一拥有数据结构特征的部分,所以joomla把它设计为MVC结构,让数据结构表现更清晰.并且component是joomla扩展开发中最复杂的部分. Joomla提供了MVC的基类:JView, JModel, JController, JTable.一个完整的joomla MVC,必须从这四个类或者其派生类继承,而Joomla2.5有更丰富的派生类,来满足joomla2.5更多的新

Chromium硬件加速渲染的GPU数据上传机制分析

在Chromium中,WebGL端.Render端和Browser端通过命令缓冲区将GPU命令发送给GPU进程执行.GPU命令携带的简单参数也通过命令缓冲区发送给GPU进程,但是复杂参数,例如纹理数据,有可能太大以致命令缓冲区无法容纳,因此需要通过其它机制传递给GPU进程.本文接下来就主要以纹理数据上传为例,分析WebGL端.Render端和Browser端将GPU命令数据传递给GPU进程的机制. 老罗的新浪微博:http://weibo.com/shengyangluo,欢迎关注! WebGL

openstack 平台搭建

环境: Controller  42.62.55.71 Compute   42.62.114.207 Controller+ Compute #yum install -y yum-plugin-priorities 配置 yum 源 Controller     compute vim/etc/yum.repos.d/openstack.repo [openstack] name=openstack baseurl=http://mirrors.ustc.edu.cn/centos/7/cl

区块链需要解决诸多问题

[摘要]数字货币行业从被热炒到归于理性平淡后,银行.交易所.审计公司等巨头开始将目光投向了比特币的底层技术——区块链. 万圣节的夜晚,伴着扮鬼搞怪的信息和区块链的热议,突然生出一个问题:区块链到底是个什么“鬼”? 2013年五部委<关于防范比特币行业风险通知>文件发布之后,一枚比特币的价格达到8000元人民币的风光早已不在,经历了Mt·Gox事件,与贩毒.走私丑闻相关联的比特币慢慢淡出舆论风口,数字货币行业从被热炒到归于理性平淡后,银行.交易所.审计公司等巨头开始将目光投向了比特币的底层技术—