新建一个空的Web项目

然后在Nuget库中安装下面两个包

  • Nancy
  • Nancy.Hosting.Aspnet

然后在根目录添加三个文件夹,分别是models,Module,Views

然后往Module文件夹里面添加ConstraintRoutingModule类

 public ConstraintRoutingModule()
{
Get("/",Lexan=>View["index"]); Get("/intConstraint/{value:int}",Lexan=>"这个值"+Lexan.value+ "是整数"); Get("/decimalConstraint/{value:decimal}",Lexan=>"这个值"+ Lexan.value+ "是十进制"); Get("/guidConstraint/{value:guid}",Lexan=>"这个值"+Lexan.value+ "是 guid"); Get("/boolConstraint/{value:bool}",Lexan=>"这个值"+Lexan.value+"是布尔值"); Get("/alphaConstraint/{value:alpha}", Lexan => "这个值" + Lexan.value + "是是信件"); Get("/datetimeConstraint/{value:datetime}", Lexan => "这个值" + Lexan.value + "是日期时间"); Get("/customDatetimeConstraint/{value:datetime(yyyy-MM-dd)}", Lexan => "这个值" + Lexan.value + "是一个日期时间, 格式为 'yyyy - mm - dd' "); Get("/minConstraint/{value:min(4)}", Lexan => "这个值" + Lexan.value + "是大于4的整数"); Get("/maxConstraint/{value:max(6)}", Lexan => "这个值" + Lexan.value + "是小于6的整数"); Get("/rangeConstraint/{value:range(10,20)}", Lexan => "这个值" + Lexan.value + "是介于10和20之间的整数"); Get("/minlengthConstraint/{value:minlength(4)}", Lexan => "这个值" + Lexan.value + "长度大于4的字符串"); Get("/maxlengthConstraint/{value:maxlength(10)}", Lexan => "这个值" + Lexan.value + "长度小于10的字符串"); Get("/lengthConstraint/{value:length(1,20)}", Lexan => "这个值" + Lexan.value + "是长度介于1和20之间的字符串"); Get("/versionConstraint/{value:version}", Lexan => "这个值" + Lexan.value + "是版本号"); Get("/emailConstraint/{value:email}", Lexan => "这个值" + Lexan.value + "是一个电子邮件地址");
}

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

 public override string Name
{
get { return "email"; }
}
protected override bool TryMatch(string constraint, string segment, out string matchedValue)
{
//throw new NotImplementedException();
//使用 @jchannon 逻辑验证电子邮件地址
if (segment.Contains("@")&&segment.Contains("."))
{
matchedValue = segment;
return true;
}
matchedValue = null;
return false;
}

然后往Views文件夹里面添加index的html页面

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<style>
table {
border-collapse:collapse;
}
table,th,td{
border:1px solid black;
padding:2px 3px;
}
</style>
</head>
<body>
<h1>约束路由</h1>
<table>约束</table>
<table>
<thead>
<tr>
<th>
约束
</th>
<th>
描述
</th>
<th>
表达
</th>
<th>
样例
</th>
</tr>
</thead>
<tbody>
<tr>
<td>alpha</td>
<td>匹配大写或小写拉丁字母字符 (a-z、a-z)</td>
<td>{x:alpha}</td>
<td><a href="/alphaConstraint/foo">成功</a><a href="/alphaConstraint/1">失败</a></td>
</tr>
<tr>
<td>bool</td>
<td>匹配布尔值</td>
<td>{x:bool}</td>
<td><a href="/boolConstraint/true">成功</a><a href="/boolConstraint/foo">失败</a></td>
</tr>
<tr>
<td>datetime</td>
<td>匹配<strong>时间</strong>值</td>
<td>{x:datetime}</td>
<td><a href="/datetimeConstraint/1-1-2010">成功</a><a href="/datetimeConstraint/foo">失败</a></td>
</tr>
<tr>
<td>decimal</td>
<td>匹配十进制值</td>
<td>{x:decimal}</td>
<td><a href="/decimalConstraint/1.5555555555555555555555555555">成功</a><a href="/decimalConstraint/foo">失败</a></td>
</tr>
<tr>
<td>guid</td>
<td>匹配guid值</td>
<td>{x:guid}</td>
<td><a href="/guidConstraint/87e516f4-c759-430d-a552-18ad8e65483b">成功</a><a href="/guidConstraint/87e516f4-c759-430d-a552-18ad8e65483bd">失败</a></td>
</tr>
<tr>
<td>int</td>
<td>匹配整数值</td>
<td>{x:int}</td>
<td><a href="/intConstraint/1">成功</a><a href="/intConstraint/foo">失败</a></td>
</tr>
<tr>
<td>length</td>
<td>与指定长度或指定范围内的字符串匹配</td>
<td>{x:length()}<br />{x:length(,)}</td>
<td><a href="/lengthConstraint/foobar">成功</a><a href="lengthConstraint/foobarfoobarfoobar">失败</a></td>
</tr>
<tr>
<td>max</td>
<td>匹配具有最大值的整数</td>
<td>{x:max()}</td>
<td><a href="/maxConstraint/5">成功</a><a href="/maxConstraint/20">失败</a></td>
</tr>
<tr>
<td>maxlength</td>
<td>匹配最大长度的字符串</td>
<td>{x:maxlength()}</td>
<td><a href="/maxlengthConstraint/foobar">成功</a><a href="/maxlengthConstraint/foobarfoobar">失败</a></td>
</tr>
<tr>
<td>min</td>
<td>匹配具有最小值的整数</td>
<td>{x:min()}</td>
<td><a href="/minConstraint/5">成功</a><a href="/minConstraint/2">失败</a></td>
</tr>
<tr>
<td>minlength</td>
<td>匹配最小长度的字符串</td>
<td>{x:minlength()}</td>
<td><a href="/minlengthConstraint/foobar">成功</a><a href="/minlengthConstraint">失败</a></td>
</tr>
<tr>
<td>range</td>
<td>匹配值范围内的整数</td>
<td>{x:range(,)}</td>
<td><a href="/rangeConstraint/15">成功</a><a href="/rangeConstraint/25">失败</a></td>
</tr>
<tr>
<td>version</td>
<td>匹配版本号</td>
<td>{x:version}</td>
<td><a href="/versionConstraint/3.2.1">成功</a><a href="/versionConstraint/-4">失败</a></td>
</tr>
<tr>
<td>email</td>
<td>匹配电子邮件地址</td>
<td>{x:email}</td>
<td><a href="/emailConstraint/mail@domain.com">成功过</a><a href="emailConstraint/maild@asdsacom">失败</a></td>
</tr>
</tbody>
</table>
</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的开源框架的使用-ConstraintRouting的更多相关文章

  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的开源框架的使用-ModelBinding(实现绑定)

    NancyFx框架中使用绑定模型 新建一个空的Web程序 然后安装Nuget库里面的包 Nancy Nancy.Hosting.Aspnet Nancy.ViewEnglines.Spark 并在We ...

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. js-将传来的数据排序,让(全部)这个小按钮小圈圈,始终排列在最前面

    let arryDemo=[]; for(var i=0;i<data.data.length;i++){ if(data.data[i].name=='全部'){ arryDemo.push( ...

  2. sh_01_判断年龄

    sh_01_判断年龄 # 1. 定义一个整数变量记录年龄 age = 15 # 2. 判断是否满了18岁 if age >= 18: # 3. 如果满了18岁,可以进网吧嗨皮 print(&qu ...

  3. Eclipse中jar包的导出与导入

    JAR的含义: JAR是Java的档案文件,是Java Archive File的缩写.jar文件是一种压缩文件,就是以特定类型压缩包的形式存在的完整Java项目.通常通过导入jar包的方式来使用实现 ...

  4. 详细讲解Android中的AbsListView的源码

    不知道各位童鞋们在开发的过程中有没有感兴趣过ListView是如何实现的呢?其实本身ListView的父类AbsListView才是关键,但是如果大家看过源码的话,会发现AbsListView将近70 ...

  5. Csharp随机生成序列码的方式Guid方法

    主要用于邮箱激活,加密等用处 Guid.NewGuid().ToString()得几种格式显示 .Guid.NewGuid().ToString("N") 结果为: 38bddf4 ...

  6. git本地文件提交

    一.github在线上传文件夹 1.点击上传文件 2 .直接拖拽 直接拖拽即可上传文件夹及文件夹里面的文件.如果点击 choose your files 就只能上传单个文件. 二.通过git工具上传本 ...

  7. vue 实现,子组件向父组件 传递数据

    首先理清组件之间的关系 组件与组件之间,还存在着不同的关系.父子关系与兄弟关系(不是父子的都暂称为兄弟吧). 父子组件 父子关系即是组件 A 在它的模板中使用了组件 B,那么组件 A 就是父组件,组件 ...

  8. linux让命令或程序在终端后台运行的方法(Ubuntu/Fedora/Centos等一样适用)

    https://segmentfault.com/a/1190000008314935

  9. 服务器上安装搭建node环境

    一.版本 : node  v4.4.3 npm  v2.15.1 pm2  v1.1.3 express v4.13.4 二.node安装与环境配置 新建node安装目录,与node项目目录     ...

  10. 关于 token

    用户在浏览器做一系列操作,后台服务怎么判断这些操作是来自同一个用户? 1. seesion 用户登录后,后台生成 sessionid 返回给浏览器,浏览器的每次请求带上 sessionid,后台关联 ...