Cache缓存帮助类

using System;
using System.Web;
using System.Collections;

namespace MSCL
{
    /// 
    /// Cache辅助类
    /// 
    public class CacheHelper
    {
        /// 
        /// 获取数据缓存
        /// 
        /// 键
        public static object GetCache(string CacheKey)
        {
            System.Web.Caching.Cache objCache = HttpRuntime.Cache;
            return objCache[CacheKey];
        }

        /// 
        /// 设置数据缓存
        /// 
        public static void SetCache(string CacheKey, object objObject)
        {
            System.Web.Caching.Cache objCache = HttpRuntime.Cache;
            objCache.Insert(CacheKey, objObject);
        }

        /// 
        /// 设置数据缓存
        /// 
        public static void SetCache(string CacheKey, object objObject, TimeSpan Timeout)
        {
            System.Web.Caching.Cache objCache = HttpRuntime.Cache;
            objCache.Insert(CacheKey, objObject, null, DateTime.MaxValue, Timeout, System.Web.Caching.CacheItemPriority.NotRemovable, null);
        }

        /// 
        /// 设置数据缓存
        /// 
        public static void SetCache(string CacheKey, object objObject, DateTime absoluteExpiration, TimeSpan slidingExpiration)
        {
            System.Web.Caching.Cache objCache = HttpRuntime.Cache;
            objCache.Insert(CacheKey, objObject, null, absoluteExpiration, slidingExpiration);
        }

        /// 
        /// 移除指定数据缓存
        /// 
        public static void RemoveAllCache(string CacheKey)
        {
            System.Web.Caching.Cache _cache = HttpRuntime.Cache;
            _cache.Remove(CacheKey);
        }

        /// 
        /// 移除全部缓存
        /// 
        public static void RemoveAllCache()
        {
            System.Web.Caching.Cache _cache = HttpRuntime.Cache;
            IDictionaryEnumerator CacheEnum = _cache.GetEnumerator();
            while (CacheEnum.MoveNext())
            {
                _cache.Remove(CacheEnum.Key.ToString());
            }
        }
    }
}
var cache = MSCL.CacheHelper.GetCache("mydata");
List list = new List();
if (cache == null)
{
	int recordCount = 0;
	int totalPage = 0;
	list = RBAC.Dal.DataRootBase.QueryPagingMssql("TestTable", "*", "D_Id asc", 2, 10, "", out recordCount, out totalPage);
	//插入cache 缓存30秒
	MSCL.CacheHelper.SetCache("mydata", list, DateTime.Now.AddSeconds(30), TimeSpan.Zero);
}
else
{
	list = (List)cache;
}


foreach (var item in list)
{
	str += string.Format("用户名{0}密码{1}真实姓名{2}--{3}
", item.D_Id, item.D_Password, item.D_Name, DateTime.Now); }



转载于:https://www.cnblogs.com/smartsmile/p/6234031.html

你可能感兴趣的:(Cache缓存帮助类)