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="1">地点 1</input> <input type="checkbox" name="Venues" value="2">地点 2</input> <input type="checkbox" name="Venues" value="3">地点 3</input> <input type="checkbox" name="Venues" value="4">地点 4</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: " + dat); $.ajax({ type: "POST", url: "/bindjson", contentType: "application/json", data: dat, success: function (data) { alert("Response: " + 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: " + dat); $.ajax({ type: "POST", url: "/bindxml", contentType: "application/xml", data: dat, success: function (data) { alert("Response: " + 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版本的基本使用,后期看看如果有空的话会继续更新,我们不见不散,哈哈哈!