NancyFx 2.0的开源框架的使用-Caching
新建一个空的Web项目,命名CachingDemo


然后添加三个Nuget安装包
- Nancy
- Nancy.Hosting.Aspnet
- Nancy.ViewsEngines.Razor

然后往项目里面添加Models,Module,Views三个文件夹

再往Models文件夹里面添加CachingExtensions文件夹

然后往CachingExtensions文件夹里面添加ContextExtensions类
public static class ContextExtensions
{
public const string OUTPUT_CACHE_TIME_KEY = "OUTPUT_CACHE_TIME"; //启用此路由的输出缓存
public static void EnableOutputCache(this NancyContext context,int seconds)
{
context.Items[OUTPUT_CACHE_TIME_KEY]=seconds;
}
//禁用此路由的输出缓存
public static void DisableOutputCache(this NancyContext context)
{
context.Items.Remove(OUTPUT_CACHE_TIME_KEY);
}
}

再往Models文件夹里面添加CachedResponse类
//在缓存的响应中封装常规响应
//缓存的响应调用旧的响应并将其存储为字符串。
//显然, 这只适用于基于 ascii 文本的响应, 所以不要使用此
//在实际应用中:-)
private readonly Response response;
public CachedResponse(Response response)
{
this.response = response;
this.ContentType = response.ContentType;
this.Headers = response.Headers;
this.Contents = this.GetContents();
}
public override Task PreExecute(NancyContext context)
{
//return base.PreExecute(context);
return this.response.PreExecute(context);
}
private Action<Stream> GetContents()
{
return stream =>
{
using (var memoryStream = new MemoryStream())
{
this.response.Contents.Invoke(memoryStream);
var contents = Encoding.ASCII.GetString(memoryStream.GetBuffer());
var writer = new StreamWriter(stream)
{
AutoFlush = true
};
writer.Write(contents);
}
};
}

然后往Module文件夹里面添加MainModule类
public MainModule()
{
Get("/",Lexan=>
{
return View["index.cshtml",DateTime.Now.ToString()];
});
Get("/cached",Lexan=>
{
this.Context.EnableOutputCache();
return View["Payload.cshtml",DateTime.Now.ToString()];
});
Get("/uncached",Lexan=>
{
this.Context.DisableOutputCache();
return View["Payload.cshtml",DateTime.Now.ToString()];
});
}

继续往根目录添加Bootstrapper类
private const int CACHE_SECONDS = ;
private readonly Dictionary<string, Tuple<DateTime, Response, int>> cachedResponses = new Dictionary<string, Tuple<DateTime, Response, int>>();
protected override void ApplicationStartup(TinyIoCContainer container, IPipelines pipelines)
{
base.ApplicationStartup(container, pipelines);
pipelines.BeforeRequest += CheckCache;
pipelines.AfterRequest += SetCache;
}
//检查我们是否有缓存条目-如果我们做了, 看看它是否已经过期,
//如果没有返回, 否则返回 null;
public Response CheckCache(NancyContext context)
{
Tuple<DateTime, Response, int> cacheEntry;
if (this.cachedResponses.TryGetValue(context.Request.Path,out cacheEntry))
{
if (cacheEntry.Item1.AddSeconds(cacheEntry.Item3)>DateTime.Now)
{
return cacheEntry.Item2;
}
}
return null;
}
//如果需要, 将当前响应添加到缓存中
//仅按路径存储, 并将响应存储在字典中。
//不要将此作为实际缓存:-)
public void SetCache(NancyContext contexts)
{
if (contexts.Response.StatusCode!=HttpStatusCode.OK)
{
return;
}
object cacheSecondsObject;
if (!contexts.Items.TryGetValue(ContextExtensions.OUTPUT_CACHE_TIME_KEY,out cacheSecondsObject))
{
return;
}
int cacheSeconds;
if (!int.TryParse(cacheSecondsObject.ToString(),out cacheSeconds))
{
return;
}
var cachedResponse = new CachedResponse(contexts.Response);
this.cachedResponses[contexts.Request.Path]=new Tuple<DateTime, Response, int>(DateTime.Now,cachedResponse,cacheSeconds);
contexts.Response = cachedResponse;
}

然后往Views文件夹里面添加index,payload,两个视图
index页面
<!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>首页</title>
</head>
<body>
<div>
<h1>缓存Demo</h1>
<p><a href="/cached">Cached页面</a></p>
<p><a href="/uncached">Uncached页面</a></p>
</div>
</body>
</html>

Payload页面
<!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>首页</title>
</head>
<body>
<div>
<h1>缓存Demo</h1>
<p>此页是在: @Model</p>
<p>这可能是或可能不会被缓存</p>
<a href="/">主页</a>
</div>
</body>
</html>

修改Web.config配置文件
<httpHandlers>
<add verb="*" type="Nancy.Hosting.Aspnet.NancyHttpRequestHandler" path="*" />
</httpHandlers>
</system.web>
<system.webServer>
<modules runAllManagedModulesForAllRequests="true" />
<validation validateIntegratedModeConfiguration="false" />
<handlers>
<add name="Nancy" verb="*" type="Nancy.Hosting.Aspnet.NancyHttpRequestHandler" path="*" />
</handlers>
</system.webServer>

然后运行一下项目F5


谢谢你的欣赏,如有不对请多多指教!
NancyFx 2.0的开源框架的使用-Caching的更多相关文章
- NancyFx 2.0的开源框架的使用-Basic
这是NancyFx开源框架中的Basic认证,学习一下! 首先当然是新建一个空的Web,BasicDemo 继续在项目中添加Nuget包,记得安装的Nuget包是最新的预发行版 Nancy Nancy ...
- NancyFx 2.0的开源框架的使用-CustomModule(自定义模块)
NancyFx框架的自定义模块 新建一个空的Web项目 然后通过NuGet库安装下面的包 Nancy Nancy.Hosting.Aspnet 然后添加Models,Module,Views三个文件夹 ...
- NancyFx 2.0的开源框架的使用-ModelBinding(实现绑定)
NancyFx框架中使用绑定模型 新建一个空的Web程序 然后安装Nuget库里面的包 Nancy Nancy.Hosting.Aspnet Nancy.ViewEnglines.Spark 并在We ...
- NancyFx 2.0的开源框架的使用-HosingOwin
Nancy框架的Owin使用 先建一个空的Web项目 然后往Nuget库里面添加Nancy包 Nancy Nancy.Owin Nancy.ViewEnglines.Spark 然后添加Models, ...
- NancyFx 2.0的开源框架的使用-Authentication
新建一个空的项目 新建好了空的项目以后,接着通过NuGet安装一下三个包 Nancy Nancy.Hosting.Aspnet Nancy.ViewEnglines.Razor 然后在项目中添加Mod ...
- NancyFx 2.0的开源框架的使用-Forms
同样的像前面2篇博文一样,每个项目的开始基本都是建个空的Web项目 在NuGet库中安装以下几个NuGet包 Nancy Nancy.Authentication.Forms Nancy.Hostin ...
- NancyFx 2.0的开源框架的使用-Stateless
同样和前面一样新建一个空的Web项目,都在根目录添加Module,Models,Views文件夹 添加Nuget包 在Models文件夹里面添加UserModel类 public string Use ...
- NancyFx 2.0的开源框架的使用-Stateless(二)
继续上一篇Stateless的博文,在上一篇的博文的基础上稍微加点东西 接下来右键解决方案添加新项目,一样建一个空的Web项目 然后在StatelessDemoWeb项目里面添加Views文件夹,Sc ...
- NancyFx 2.0的开源框架的使用-AspnetBootstrapping
新建一个空的Web项目AspnetBootstrappingDemo 然后添加NuGet组件 Nancy Nancy.Hosting.Aspnet Nancy.ViewEngines.Razor 继续 ...
随机推荐
- JavaScript对象的深浅复制
前言 从层次上来看,对象的复制可以简单地分为浅复制和深复制,顾名思义,浅复制是指只复制一层对象的属性,不会复制对象中的对象的属性,对象的深复制会复制对象中层层嵌套的对象的属性. 在复制对象时,除了要复 ...
- 一键部署Kubernetes高可用集群
三台master,四台node,系统版本为CentOS7 IP ROLE 172.60.0.226 master01 172.60.0.86 master02 172.60.0.106 master0 ...
- Snapman设计中的思考
Snapman主页:http://www.snapman.xyz 原文链接地址:http://www.snapman.xyz/newsitem/277785310 feiren工作室主要研究人类 ...
- asp.net core源码飘香:从Hosting开始
知识点: 1.Kestrel服务器启动并处理Http请求的过程. 2.Startup的作用. 源码飘香: 总结: asp.net core将web开发拆分为多个独立的组件,大多以http中间件的形式添 ...
- JavaScript 格式化时间
//格式化 yyyy-MM-dd hh:mm:ss function renderTime(date) { if (date == '' || date == null) { return ''; } ...
- 使用点击二分图计算query-document的相关性
之前的博客中已经介绍了Ranking Relevance的一些基本情况(Click Behavior,和Text Match):http://www.cnblogs.com/bentuwuying/p ...
- MyBatis注解配置动态SQL
MySQL创建表 DROP TABLE IF EXISTS `tb_employee`; CREATE TABLE `tb_employee` ( `id` int(11) NOT NULL AUTO ...
- C字符串处理函数
部分参考百科. C常用字符串函数:字符串输入函数,字符串输出函数,字符串处理函数,标准输入输出流 字符串处理函数: 1.字符串长度:strlen(str),返回字符串实际长度,不包括'\0',返回值类 ...
- angular双向数据绑定
<body ng-app> //三个view都会变 <input type="text" ng-model="name" value=&quo ...
- zepto.js介绍
是一个阉割版的jQuery zepto不支持jQuery过于复杂的选择器,比如:first :last :eq zepto如果要用动画必须再次引包 zepto能将css3中transition支持的动 ...