今天来做个基于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,开始写代码了 1 class Program 2 { 3 static void Main(string[] args) 4 { 5 using (var nancySelfHost = new NancyHost(new Uri("http://localhost:8888/"))) 6 { 7 nancySelfHost.Start(); 8 Console.WriteLine("NancySelfHost已启动。。"); 9 try10 {11 Console.WriteLine("正在启动 http://localhost:8888/ ");12 System.Diagnostics.Process.Start("http://localhost:8888/");13 Console.WriteLine("成功启动 http://localhost:8888/ ");14 }15 catch (Exception)16 {17 }18 Console.Read();19 }20 Console.WriteLine("http://localhost:8888 已经停止 \n NancySelfHost已关闭。。"); 21 }22 }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 1 public class HomeModule:NancyModule2 {3 public HomeModule()4 {5 Get["/"] = _ => "I'm from Nancy.Hosting.Self!";6 }7 } HomeModule.cs

运行一下,看看效果

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

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

新建Home文件夹,新建index.html,这里我们就不用Razor了,Nancy支持多种视图引擎!!这个很不错。 1 2 3 4 5 NancyDemo 6 7 8

SelfHostingDemo 9 10 index.html

同时对HomeModule.cs进行修改 1 public class HomeModule:NancyModule 2 { 3 public HomeModule() 4 { 5 Get["/"] = _ => 6 { 7 return View["index"]; 8 }; 9 10 }11 }HomeModule.cs

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

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

既然有错误,就要排除错误,看看它说那里有问题: Nancy.RequestExecutionException: Oh noes! ---> Nancy.ViewEngines.ViewNotFoundException: Unable to locate view 'index'Currently available view engine extensions: sshtml,html,htmLocations inspected: views/Home/index-zh-CN,views/Home/index,Home/index-zh-CN,Home/index,views/index-zh-CN,views/index,index-zh-CN,indexRoot path: D:\GithubCode\Demos\NancyDemoWithSelfHosting\SelfHostingDemo\SelfHostingDemo\bin\DebugIf 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

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

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

nancy 显示html网页,Nancy之基于Nancy.Hosting.Self的小Demo_html/css_WEB-ITnose相关推荐

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

    原文:Nancy之基于Self Hosting的补充小Demo 前面把Hosting Nancy with ASP.NET.Self Hosting Nancy和Hosting Nancy with ...

  2. nancy 显示html网页,Nancy之静态文件处理_html/css_WEB-ITnose

    今天我们来谈谈Nancy中的静态文件(JavaScript,CSS等)该如何处理. 在前面的Demo中,我们也已经用到了这一块的内容, 但并没有深入理解,只是停留在使用的层面上. 在进入今天的正题之前 ...

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

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

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

    Nancy之基于Nancy.Hosting.Aspnet的小Demo 原文:Nancy之基于Nancy.Hosting.Aspnet的小Demo 近来学习了一下Nancy这个框架,感觉挺好用的,就写篇 ...

  5. Nancy in .Net Core学习笔记 - 初识Nancy

    原文:Nancy in .Net Core学习笔记 - 初识Nancy 前言 去年11月份参加了青岛MVP线下活动,会上老MVP衣明志介绍了Nancy, 一直没有系统的学习一下,最近正好有空,就结合. ...

  6. Chrome浏览器出现无法访问此网站/无法显示此网页的错误,怎么解决?

    出现"无法访问此网站"或"无法显示此网页"的错误,有很多原因会导致这个问题发生,下面说明如何解决这个问题. 升级Chrome到最新版本,首先确认您的Chrome ...

  7. Mongodb网页管理工具,基于Spring Boot2.0,前端采用layerUI实现

    源码:https://github.com/a870439570/Mongodb-WeAdmin 项目介绍 Mongodb网页管理工具,基于Spring Boot2.0,前端采用layerUI实现. ...

  8. studio2008 无法显示该网页

    莫名奇妙的studio调试的时候页面显示无法显示该网页,差网页后得知原来是C:\WINDOWS\system32\drivers\etc下的Hosts文件被修改了, 确认里面有127.0.0.1    ...

  9. 使用php读写mysql数据库并显示到网页上

    由于工作的原因,需要了解下bs模式下的读写数据库的流程,将试验过程梳理一下. 我采用的是phpstudy搭建数据库,mysql数据库已经搭建完成,名称为2018版本,如下图: 由于我前期安装过apac ...

最新文章

  1. Android2.2 API 中文文档系列(7) —— ImageButton
  2. leetcode算法题--一周中的第几天
  3. Python练习3-XML-RPC实现简单的P2P文件共享
  4. androidrunnable使用,Android的:如何停止的Runnable?
  5. python集合数据对象_python学习第七天 基础数据类型补充 深浅copy 集合 关键字后面加可迭代对象...
  6. maven依赖管理_依赖管理和Maven
  7. caffe安装_目标检测之caffe-ssd模型训练与测试
  8. 一个人成长最快速的方法
  9. NET CMS 大全
  10. mysql死锁语句_记一次神奇的Mysql死锁排查
  11. 《计算机网络》第一章:基础知识Part II
  12. 使用C语言在Win控制台中输出带颜色的文字
  13. smarty中的在模板页中应用js css img等文件时,地址是相对与模板页对应的php文件
  14. 基于单片机的贪吃蛇游戏设计仿真
  15. DevExpress WinForm控件入门指南——数据管理控件
  16. JavaGUI实现科学计算器
  17. I2S协议及在verilog中实现
  18. 【Linux学习笔记】关于ubuntu开机菜单栏和任务栏不见了的有效解决方法
  19. 【hadoop】 3007-hadoop的提交job的源码分析
  20. UWP 禁止Pivot swip 手势

热门文章

  1. DTSD79-W1型三相四线电子式多功能电能表驱动通讯
  2. LFM雷达实现及USRP验证【章节1:LFM基本原理】
  3. edas部署需要哪些参数_edas配置
  4. 联想电脑服务器未能登录,联想电脑输入开机密码后显示group policy client 服务未能登录,拒绝访问是为什么?...
  5. Linux学习之centOs的安装(二)
  6. 承载多云时代“数字化枢纽”使命,存储如何满足金融业期待?
  7. 炉石传说服务器维护有补偿吗,炉石传说2017年服务器故障回档补偿公告
  8. 3.临床预测模型的构建--基础知识
  9. 只要你认真看完一万字☀️Linux操作系统基础知识☀️分分钟钟都吊打面试官《❤️记得收藏❤️》
  10. C# decimal