继昨天的Nancy之基于Nancy.Hosting.Aspnet的小Demo后,

今天来做个基于Nancy.Hosting.Self的小Demo。

关于Self Hosting Nancy,官方文档的介绍如下

https://github.com/NancyFx/Nancy/wiki/Self-Hosting-Nancy

文档具体的内容我就不一一翻译了,主要是演示从头到尾的一个过程,然后看看Nancy.Hosting.Self的源码

一、新建一个控制台应用程序(Console Application)

二、通过NuGet添加我们需要的Nancy包

这里我们可以直接添加Nancy.Hosting.Self,添加这个会顺带添加Nancy。

到这里我们的基本工作就KO了。

三、打开Program.cs,开始写代码了

     class Program
{
static void Main(string[] args)
{
using (var nancySelfHost = new NancyHost(new Uri("http://localhost:8888/")))
{
nancySelfHost.Start();
Console.WriteLine("NancySelfHost已启动。。");
try
{
Console.WriteLine("正在启动 http://localhost:8888/ ");
System.Diagnostics.Process.Start("http://localhost:8888/");
Console.WriteLine("成功启动 http://localhost:8888/ ");
}
catch (Exception)
{
}
Console.Read();
}
Console.WriteLine("http://localhost:8888 已经停止 \n NancySelfHost已关闭。。");
}
}

Program.cs

这里实例化了一个新的NancyHosting,并直接用Process.Start打开了一个网页。

这样做是为了省时省力偷下懒,不用在启动程序之后再手动去打开浏览器去输入http://localhost:8888

如果不熟悉Process,可以看一下这个

https://msdn.microsoft.com/en-us/library/e8zac0ca(v=vs.110).aspx

四、新建一个Modules文件夹,用来存放我们的Modules

在Modules文件夹新建一个HomeModule.cs

     public class HomeModule:NancyModule
{
public HomeModule()
{
Get["/"] = _ => "I'm from Nancy.Hosting.Self!";
}
}

HomeModule.cs

运行一下,看看效果

正是我们要的结果。下面来看看视图有没有问题。

五、建一个Views文件夹,用于存放视图

新建Home文件夹,新建index.html,这里我们就不用Razor了,Nancy支持多种视图引擎!!这个很不错。

 <!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8" />
<title>NancyDemo</title>
</head>
<body>
<p style="font-size:xx-large">SelfHostingDemo</p>
</body>
</html>

index.html

同时对HomeModule.cs进行修改

     public class HomeModule:NancyModule
{
public HomeModule()
{
Get["/"] = _ =>
{
return View["index"];
}; }
}

HomeModule.cs

运行试试。oh no~~  出错了。。。

为什么会出现错误呢?不应该啊!!

既然有错误,就要排除错误,看看它说那里有问题:

Nancy.RequestExecutionException: Oh noes! ---> Nancy.ViewEngines.ViewNotFoundException: Unable to locate view 'index'
Currently available view engine extensions: sshtml,html,htm
Locations inspected: views/Home/index-zh-CN,views/Home/index,Home/index-zh-CN,Home/index,views/index-zh-CN,views/index,index-zh-CN,index
Root path: D:\GithubCode\Demos\NancyDemoWithSelfHosting\SelfHostingDemo\SelfHostingDemo\bin\Debug
If you were expecting raw data back, make sure you set the 'Accept'-header of the request to correct format, for example 'application/json' 提示的居然是没有找到视图!!再细细看一下就会发现问题了。Root path!!!!
视图应该在放到Debug目录下,这里建的是控制台应用程序,不是web应用程序。
所以就把Views文件夹搬家到Debug下面。
运行看看,OK,成功了

六、把这个demo放到linux下看看 在 /var/www/ 下面新建一个文件夹 mkdir nancydemo
将程序bin目录下的文件传到 /var/www/nancydemo 中,ls看一下里面的内容

执行 mono SelfHostingDemo.exe
看看效果,OK!
到这里,已经完成了一个简单的Demo了。 趁着时间还早,看看Nancy.Hosting.Self的内部实现,源码地址:
https://github.com/NancyFx/Nancy/tree/master/src/Nancy.Hosting.Self

还记得否?我们的Program.cs中有用到这个类----NancyHost
var nancySelfHost = new NancyHost(new Uri("http://localhost:8888/"))
细细看看这个类里面有什么东西。
https://github.com/NancyFx/Nancy/blob/master/src/Nancy.Hosting.Self/NancyHost.cs

有六个重载,其实这六个重载都是为了初始化 NancyHost ,有三个是用了默认配置,有三个是用了自定义配置。

我们用到的NancyHost是采用的默认配置,参数就是一个可变的Uri数组。

然后看看Start 方法

主要是监听我们的请求,这个监听过程主要用到了HttpListener,还有异步回调。

里面的 Task.Factory.StartNew 可以看看msdn的介绍

https://msdn.microsoft.com/en-us/library/dd321439(v=vs.110).aspx

持续降温。。注意保暖。。

Nancy之基于Nancy.Hosting.Self的小Demo的更多相关文章

  1. Nancy之基于Self Hosting的补充小Demo

    前面把Hosting Nancy with ASP.NET.Self Hosting Nancy和Hosting Nancy with OWIN 以demo的形式简单描述了一下. 这篇是为Self H ...

  2. Nancy之基于Nancy.Owin的小Demo

    前面做了基于Nancy.Hosting.Aspnet和Nancy.Hosting.Self的小Demo 今天我们来做个基于Nancy.Owin的小Demo 开始之前我们来说说什么是Owin和Katan ...

  3. 一个基于ES6+webpack的vue小demo

    上一篇文章<一个基于ES5的vue小demo>我们讲了如何用ES5,vue-router做一个小demo,接下来我们来把它变成基于ES6+webpack的demo. 一.环境搭建及代码转换 ...

  4. Nancy之基于Nancy.Hosting.Aspnet的小Demo

    近来学习了一下Nancy这个框架,感觉挺好用的,就写篇简单的文章记录一下大致用法,由于是刚接触,写的代码 可能不规范,也没有具体的分层..莫吐槽... Nancy的官网:http://nancyfx. ...

  5. 一个基于ES5的vue小demo

    由于现在很多vue项目都是基于ES6开发的,而我学vue的时候大多是看vue官网的API,是基于ES5的,所以对于刚接触项目的我来说要转变为项目的模块化写法确实有些挑战.因此,我打算先做一个基于ES5 ...

  6. 基于FPGA的飞机的小游戏

    基于FPGA的飞机的小游戏 实验原理 该实验主要分为4个模块,采用至上而下的设计方法进行设计.由50M的晶振电路提供时钟源,VGA显示控制模块.图形显示控制模块.移动模块的时钟为25M,由时钟分频电路 ...

  7. 基于HTML5实现五彩连珠小游戏

    今天给大家分享一款基于HTML5实现五彩连珠小游戏.这款游戏的规则:点击彩球移动到期望的位置,每移动一次,画面将随机出现3个新的彩球:当同一颜色的彩球连成5个一行或一列或一斜线时,这5个彩球同时消失, ...

  8. 基于Shiro,JWT实现微信小程序登录完整例子

    小程序官方流程图如下,官方地址 : https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html ...

  9. CRMEB系统就是集客户关系管理+营销电商系统,能够真正帮助企业基于微信公众号、小程序实现会员管理、数据分析,精准营销的电子商务管理系统。可满足企业新零售、批发、分销、等各种业务需求。

    **可以快速二次开发的开源小程序商城系统源码**源码开源地址:https://github.crmeb.net/u/LXT 项目介绍: CRMEB系统就是集客户关系管理+营销电商系统,能够真正帮助企业 ...

随机推荐

  1. 手机CPU和GPU厂商

    CPU: 1.苹果 (Apple) A系列 ARM授权,基于Cortex-A系列架构 A5基于Cortex-A9架构,双核,主频800M-1Ghz,内存双通道32bitLPDDR2,GPU采用Powe ...

  2. 解决读取iphone名称中文乱码问题

    #region 解决中文乱码 Ethan 2016-01-06 [DllImport("iTunesMobileDevice.dll", CallingConvention = C ...

  3. 【腾讯Bugly干货分享】微信小程序开发思考总结——腾讯“信用卡还款”项目实践

    本文来自于腾讯bugly开发者社区,未经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/58212d0fa7a7574c4f4cc3c5 作者:peggy 小程序概述 1 ...

  4. 搭建前端私有npm杂记

    随着前端队伍越来越壮大,项目间共享代码就变得尤为重要.常用的框架/类库没必要在每个项目都放一份,团队内部产出的公共模块也需要有合理的共享机制.现在,用npm管理前端代码已经是业界趋势.楼主尝试用私有n ...

  5. java中文乱码解决之道(六)-----javaWeb中的编码解码

    在上篇博客中LZ介绍了前面两种场景(IO.内存)中的java编码解码操作,其实在这两种场景中我们只需要在编码解码过程中设置正确的编码解码方式一般而言是不会出现乱码的.对于我们从事java开发的人而言, ...

  6. 微冷的雨Java基础学习手记(一)

    使用Java理解程序逻辑 之凌波微步 船舶停靠在港湾是很安全的,但这不是造船的目的 北大青鸟五道口原玉明老师出品 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识点时,要 ...

  7. C语言 · 出现次数最多的数

    问题描述 编写一个程序,读入一组整数,这组整数是按照从小到大的顺序排列的,它们的个数N也是由用户输入的,最多不会超过20.然后程序将对这个数组进行统计,把出现次数最多的那个数组元素值打印出来.如果有两 ...

  8. Chrome开发者工具不完全指南:(三、性能篇)

    卤煮在前面已经向大家介绍了Chrome开发者工具的一些功能面板,其中包括Elements.Network.Resources基础功能部分和Sources进阶功能部分,对于一般的网站项目来说,其实就是需 ...

  9. "org.eclipse.wst.validation" has been removed 导入maven 项目出错。

    在谷歌中找到解决方案: 右键关闭项目,在打开,将项目刷新,选中项目右键----->Maven4myeclipse------->Update maven project 错误消失. 若还有 ...

  10. GitFlow

    git工作流 始终保持有master分支(只要有目录,git就自动创建)和develop分支(手动创建) 一.主分支Master二.开发分支Develop三.临时性分支(最后发布要删除的)* 功能(f ...