NancyFx框架中使用绑定模型

新建一个空的Web程序

然后安装Nuget库里面的包

  • Nancy
  • Nancy.Hosting.Aspnet
  • Nancy.ViewEnglines.Spark

并在Web应用程序里面添加Models,Module,Views三个文件夹

继续往Models文件夹里面添加Database,ModelBinders

然后往Models文件夹里面添加Customer类

        public int Id { get; set; }
public string Name { get; set; }
public DateTime RenewalDate { get; set; }

继续往Models文件夹里面添加Event类

        public int Id { get; set; }
public string Title { get; set; }
public string Location { get; set; }
public IEnumerable<int> Venues { get; set; }
public DateTime Time { get; set; }
public Event()
{
this.Title = "Lexan";
this.Location = "Lexan";
this.Time = DateTime.Now;
}

继续往Models文件夹里面添加User类

        public string Name { get; set; }
public string Address { get; set; }

然后往Database文件夹里面添加DB类

        public static List<Event> Events { get; private set; }
public static List<Customer> Customer { get; private set; } static DB()
{
Events = new List<Models.Event>();
Customer = new List<Models.Customer>();
}

然后往ModelBinders文件夹里面添加CustomerModelBinder类

//是否可以绑定到给定的模型类型
public bool CanBind(Type modelType)
{
return modelType == typeof(Customer);
}
//绑定到给定的模型类型
public object Bind(NancyContext context,Type modelType, object instance,BindingConfig configuration,params string[] blackList)
{
var customer = (instance as Customer) ?? new Customer();
customer.Name = customer.Name ?? context.Request.Form["Name"];
customer.RenewalDate = customer.RenewalDate == default(DateTime) ? context.Request.Form["RenewalDate"] : customer.RenewalDate;
return customer;
}

然后往Module里添加MainModule类

 public MainModule()
{
Get("/", Lexan =>
{
return "<a href='/events'>Events (默认模型绑定)</a><br><a href='/customers'>Customers (自定义模型绑定)</a><br><a href='/bindjson'>Users (JSON)</a></a><br><a href='/bindxml'>Users (XML)</a><br>";
});
}

然后往Module里添加CustomersModule类

 public CustomersModule() : base("/customers")
{
Get("/",Lexan=>
{
var model = DB.Customer.OrderBy(e=>e.RenewalDate).ToArray();
return View["Customers",model];
});
Post("/",Lexan=>
{
Customer model = this.Bind();
var models = this.Bind<Customer>();
DB.Customer.Add(model);
DB.Customer.Add(models);
return this.Response.AsRedirect("/Customers");
});
}

然后往Module里添加EventsModule类

 public EventsModule():base("/events")
{
Get("/",Lexan=>
{
var model = DB.Events.OrderBy(x=>x.Time).ToArray();
return View["Events",model];
});
Post("/",Lexan=>
{
Event model = this.Bind();
var models = this.Bind<Event>("Location");
DB.Events.Add(model);
DB.Events.Add(models);
return this.Response.AsRedirect("/Events");
});
}

然后往Module里添加JsonModule类

  public JsonModule()
{
Get("/bindjson",Lexan=>
{
return View["PostJson"];
});
Post("/bindjson",Lexan=>
{
User model = this.Bind();
var sb = new StringBuilder();
sb.AppendLine("绑定模型:");
sb.Append("类型:");
sb.AppendLine(model.GetType().FullName);
sb.Append("名字:");
sb.AppendLine(model.Name);
sb.Append("地址:");
sb.AppendLine(model.Address);
return sb.ToString();
});
}

然后往Module里添加XmlModule类

 public XmlModule()
{
Get("/bindxml",Lexan=>
{
return View["PostXml"];
});
Post("/bindxml",Lexan=>
{
var model = this.Bind<User>(x=>x.Name);
var sb = new StringBuilder();
sb.AppendLine("绑定模型:");
sb.Append("类型:");
sb.AppendLine(model.GetType().FullName);
sb.Append("名字:(这将是空的, 因为它被忽略)");
sb.AppendLine(model.Name);
sb.Append("地址:");
sb.AppendLine(model.Address);
return sb.ToString(); });
}

然后往根目录里面添加Bootstrapper类

然后往Views文件夹里面添加Customers.txt文件

然后把Customers.txt改成Customers.spark

添加如下内容

<viewdata model="ModelBindingDemo.Models.Customer[]"/>
<html>
<head>
<title>客户</title>
</head>
<body>
<h1>客户</h1>
<p>客户被添加了两次, 一个使用动态活页夹适配器, 另一个使用通用的.</p>
<p>当前客户:</p>
<ul>
<li each="var v in Model">
<a href="customer/${v.Id}"> ${v.Name} - ${v.RenewalDate.ToShortDateString()} </a>
</li>
</ul> <h2>添加另一个</h2>
<form method="POST" action="/customers">
<label for="Name">名字</label>
<input type="text" name="Name" />
<label for="Location">更新日期</label>
<input type="text" name="RenewalDate" />
<input type="submit"/>
</form>
</body>
</html>

同样的做法添加Event.txt添加成功后改成Event.spark

 并添加如下内容

<viewdata model="ModelBindingDemo.Models.Event[]"/>
<html>
<head>
<title>事件</title>
</head>
<body>
<h1>事件</h1>
<p>事件被添加两次, 一个使用动态活页夹适配器, 另一个使用通用的.</p>
<p>第二个有 ' 位置 ' 标记为黑名单, 因此应该显示为 ' 默认 '</p>
<p>当前事件:</p>
<ul>
<li each="var v in Model">
<a href="event/${v.Id}"> ${v.Title} - ${v.Location} </a> ${v.Time}
</li>
</ul> <h2>Add another</h2>
<form method="POST" action="/events">
<label for="Name">标题</label>
<input type="text" name="Title" />
<label for="Location">位置</label>
<input type="text" name="Location" /> <input type="checkbox" name="Venues" value="">地点 </input>
<input type="checkbox" name="Venues" value="">地点 </input>
<input type="checkbox" name="Venues" value="">地点 </input>
<input type="checkbox" name="Venues" value="">地点 </input> <label for="EventDate">时间</label>
<input type="text" name="Time" value="${System.DateTime.Now}"/>
<input type="submit"/>
</form>
</body>
</html>

 然后继续再Views文件夹里面添加PostJson.html

<html>
<head>
<title>JSON Post Test</title>
<script type="text/javascript">
$(function () {
var dat = "{\"Name\":\"This is the name\", \"Address\":\"This is the address\"}"; alert("将以下数据粘贴到 /bindjson:\n\n" + dat); $.ajax({
type: "POST",
url: "/bindjson",
contentType: "application/json",
data: dat,
success: function (data) {
alert("Response:\n" + data);
}
});
});
</script>
</head>
<body>
JSON Post
</body>
</html>

继续添加PostXml.html页面

<html>
<head>
<title>XML Post Test</title>
<script type="text/javascript">
$(function () {
var dat = "<User><Name>这是名字</Name><Address>这是地址</Address></User>"; alert("将以下数据粘贴到 /bindxml:\n\n" + dat); $.ajax({
type: "POST",
url: "/bindxml",
contentType: "application/xml",
data: dat,
success: function (data) {
alert("Response:\n" + data);
}
});
});
</script>
</head>
<body>
XML Post
</body>
</html>

最后修改Web.config配置文件

    <httpRuntime targetFramework="4.5.2"/>
<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>

现在我们看看运行的结果

到这里就结束了,感谢你的欣赏,这篇也算介绍完了NancyFx2.0版本的基本使用,后期看看如果有空的话会继续更新,我们不见不散,哈哈哈!

NancyFx 2.0的开源框架的使用-ModelBinding(实现绑定)的更多相关文章

  1. NancyFx 2.0的开源框架的使用-Basic

    这是NancyFx开源框架中的Basic认证,学习一下! 首先当然是新建一个空的Web,BasicDemo 继续在项目中添加Nuget包,记得安装的Nuget包是最新的预发行版 Nancy Nancy ...

  2. NancyFx 2.0的开源框架的使用-CustomModule(自定义模块)

    NancyFx框架的自定义模块 新建一个空的Web项目 然后通过NuGet库安装下面的包 Nancy Nancy.Hosting.Aspnet 然后添加Models,Module,Views三个文件夹 ...

  3. NancyFx 2.0的开源框架的使用-HosingOwin

    Nancy框架的Owin使用 先建一个空的Web项目 然后往Nuget库里面添加Nancy包 Nancy Nancy.Owin Nancy.ViewEnglines.Spark 然后添加Models, ...

  4. NancyFx 2.0的开源框架的使用-Authentication

    新建一个空的项目 新建好了空的项目以后,接着通过NuGet安装一下三个包 Nancy Nancy.Hosting.Aspnet Nancy.ViewEnglines.Razor 然后在项目中添加Mod ...

  5. NancyFx 2.0的开源框架的使用-Forms

    同样的像前面2篇博文一样,每个项目的开始基本都是建个空的Web项目 在NuGet库中安装以下几个NuGet包 Nancy Nancy.Authentication.Forms Nancy.Hostin ...

  6. NancyFx 2.0的开源框架的使用-Stateless

    同样和前面一样新建一个空的Web项目,都在根目录添加Module,Models,Views文件夹 添加Nuget包 在Models文件夹里面添加UserModel类 public string Use ...

  7. NancyFx 2.0的开源框架的使用-Stateless(二)

    继续上一篇Stateless的博文,在上一篇的博文的基础上稍微加点东西 接下来右键解决方案添加新项目,一样建一个空的Web项目 然后在StatelessDemoWeb项目里面添加Views文件夹,Sc ...

  8. NancyFx 2.0的开源框架的使用-AspnetBootstrapping

    新建一个空的Web项目AspnetBootstrappingDemo 然后添加NuGet组件 Nancy Nancy.Hosting.Aspnet Nancy.ViewEngines.Razor 继续 ...

  9. NancyFx 2.0的开源框架的使用-Caching

    新建一个空的Web项目,命名CachingDemo 然后添加三个Nuget安装包 Nancy Nancy.Hosting.Aspnet Nancy.ViewsEngines.Razor 然后往项目里面 ...

随机推荐

  1. MongoDB基础教程系列--第二篇 MongoDB基本操作(一)

    1.安装环境 在官网上下载MongoDB的最新版本,根据自身Windows版本下载正确的MongoDB版本.下载后,双击32位或者64位.msi文件,按操作提示安装就可以了. 说明: 32 位版本的 ...

  2. Java中类的继承,属性和方法的四种修饰符的作用范围,final关键字,java的三大特点中的2个:封装和多态,以及多态的一个设计模式,模板方法模式(template method)

    (一)Java中的继承: 关于继承,在Java中类的继承只能是单继承,不像C+++那样灵活,可以多继承,多继承的后果就是各种关系乱套,就相当于一个孩子有2个母亲一样,社会关系的复杂,不利于程序后期的开 ...

  3. 用webpack搭建react开发环境

    安装插件: npm install react react-dom babel-loader babel-core babel-preset-react babel-preset-es2015 配置w ...

  4. 安全性测试之防范 DDoS 攻击

    安全性测试之防范 DDoS 攻击   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:90882 ...

  5. 4.Linux的文件搜索命令

    1.文件搜索命令  which 语法:which [命令名称] 范例:$which ls  列出ls命令所在目录 [chanshuyi@localhost ~]$ which ls alias ls= ...

  6. zoom动画,实现图片点击预览效果

    参考:https://developer.android.google.cn/training/animation/zoom.html 1.创建Views 下面的布局包括了你想要zoom的大版本和小版 ...

  7. 用 config drive 配置网络 - 每天5分钟玩转 OpenStack(173)

    上一节最后问了大家一个问题:如果 subnet 没有开 DHCP,会是怎样一个情况? 在其他条件不变的情况下,cloud-init 依然会完成那 3 个步骤,也就是说网卡还是会被配置成 dhcp 模式 ...

  8. 简聊iOS支付集成(支付宝和微信支付)

    一.支付集成是什么 1.现在大部分app都有快捷支付功能,支付集成将第三方支付平台集成到自己的项目中,能够完成自己项目中的支付功能, 二.支付集成的使用 <1>.支付宝: 下载SDK和De ...

  9. 混合式app ionic2.x 手动搭建开发环境教程分享(nodejs,jdk,ant,androidsdk)

    1.ionic简介 为什么选用ionic: 彻底开源且免费 性能优异 基于红的发紫的AngularJs 漂亮的UI 强大的命令行(基于更热门的nodejs) 开发团队非常活跃 ngCordova,将主 ...

  10. Python学习_ConfigParse (转)

    1.基本的读取配置文件   -read(filename) 直接读取ini文件内容 -sections() 得到所有的section,并以列表的形式返回 -options(section) 得到该se ...