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 继续 ...
随机推荐
- vuejs2.0子组件改变父组件的数据
在vue2.0之后的版本中,不允许子组件直接改变父组件的数据,在1.0的版本中可以这样操作的,但是往往项目需求需要改变父组件的数据,2.0也是可一个,区别是,当我们把父元素的数据给子组件时,需要传一个 ...
- 【C++】模拟实现auto_ptr
看了<Effctive C++>,里面提到用对象去管理资源,可以有效防止内存泄漏. 结合auto_ptr特性,稍微思考了一下,实现了一个简单的auto_ptr (因为代码量小,就不分文件了 ...
- OpenStack及其构成简介
新的一年新的开始,突然想学习下Openstack,之前了解过很多,但是想系统的学习一下,第一次写博客,只想把学到的东西记录下来加深印象,如有写的不好的地方请多多见谅.下面开门见山. 1.What is ...
- WCF消息压缩
对于WCF应用来说,传输前压缩请求消息和回复消息,不但可以降低网络流量,也可以提高网络传输的性能 一.消息压缩方案 二.用于数据压缩与解压缩组件 三.用于消息压缩与解压的组件 四.用于对请求/回复消息 ...
- hdu 2516 取石子游戏 (斐波那契博弈)
题意:1堆石子有n个,两人轮流取.先取者第1次可以取任意多个,但不能全部取完.以后每次取的石子数不能超过上次取子数的2倍. 取完者胜,先取者负输出"Second win",先取者胜 ...
- javascript里的几种常见的数组方法
Array()的几种方法 1.splice(2,3,4)删除数组中任意项(三个参数). 2.splice(1,3)删除从第一项开始的往后三项(两个参数).(splice可以结合pop(),unshif ...
- mac jmeter 的使用
1.下载 mac下载地址:http://jmeter.apache.org/download_jmeter.cgi,下载apache-jmeter-3.1.tgz 2.下载完毕后解压,得到安装包 3. ...
- DIV+CSS清除浮动方法
一.为什么要清除浮动? 1>父元素在未定义高的情况下,由于子元素全部浮动脱离文本流,而造成父元素高的塌陷(正常情况下,父元素的高是由未浮动的子元素撑起来) 2>因为部分子元素的而浮动,脱离 ...
- Asp .Net MVC4笔记之目录结构
认识MVC从目录结构开始,从基本创建开始. App_Data 文件夹:App_Data 文件夹用于存储应用程序数据. App_Start:启动文件的配置信息,包括很重要的RouteConfig路由注册 ...
- 1.2 N层架构
N层架构 介绍 ABP架构 其他(通用) 领域层 应用层 基础设施层 网络和展现层 其他 总结 介绍 应用程序代码库的分层架构是被广泛认可的可以减少程序复杂度.提高代码复用率的技术.为了实现分层架构, ...