同样的像前面2篇博文一样,每个项目的开始基本都是建个空的Web项目

在NuGet库中安装以下几个NuGet包

  • Nancy
  • Nancy.Authentication.Forms
  • Nancy.Hosting.Aspnet
  • Nancy.ViewEngines.Razor

项目中同样分别建Module,Models,Views 三个文件夹,并在Module文件夹里面添加MainModule类

 public MainModule()
{
Get("/", Lexan => { return View["index"]; });
Get("/login", Lexan =>
{
dynamic model = new ExpandoObject();
model.Errored = this.Request.Query.error.HasValue;
return View["login",model];
});
}

接着往Models文件夹里面添加UserDatabase类

private static List<Tuple<string, string, Guid>> user = new List<Tuple<string, string, Guid>>();
static UserDatabase()
{
//guid码是一个唯一的id,这个id可以自己另外写一个guid生成器去生成
//登陆账号Lexan,密码是password
user.Add(new Tuple<string, string, Guid>("Lexan","password",new Guid("87e516f4-c759-430d-a552-18ad8e65483b")));
}
public ClaimsPrincipal GetUserFromIdentifier(Guid identifier,NancyContext context)
{
//guid值赋给userRecord
var userRecord = user.FirstOrDefault(x=>x.Item3==identifier);
return userRecord == null ? null : new ClaimsPrincipal(new GenericIdentity(userRecord.Item1));
}
public static Guid? ValidateUser(string username,string password)
{
var usersRecord = user.FirstOrDefault(x=>x.Item1==username&&x.Item2==password);
if (usersRecord==null)
{
return null;
}
return usersRecord.Item3;
}

接着继续回到MainModule文件夹里面去写完类里面的post登陆方法和get登出方法

 Post("/login",Lexan=>
{
var userGuid = UserDatabase.ValidateUser((string)this.Request.Form.Username,(string)this.Request.Form.Password);
if (userGuid==null)
{
return this.Context.GetRedirect("~/login?error=true&username="+(string)this.Request.Form.Username);
}
DateTime? expiry = null;
if (this.Request.Form.RememberMe.HasValue)
{
expiry = DateTime.Now.AddDays();
}
return this.LoginAndRedirect(userGuid.Value,expiry);
});
//登出,并返回到主页
Get("/logout",Lexan=> { return this.LogoutAndRedirect("~/"); });

继续往Module文件夹里面添加PartlySecureModule类,SecureModule类,以及Models文件里面添加UserModel类

 public PartlySecureModule():base("/partlysecure")
{
Get("/",Lexan=>"");
Get("/secured",Lexan=>
{
this.RequiresAuthentication();
//获取UserModel里面的Name值
var model = new UserModel(this.Context.CurrentUser.Identity.Name);
return View["secure.cshtml",model];
});
}

SecureModule类

  public SecureModule():base("/secure")
{
this.RequiresAuthentication();
Get("/",Lexan=>
{
var model = new UserModel(this.Context.CurrentUser.Identity.Name);
return View["secure.cshtml",model];
});
}

UserModel类

        public string Username { get; set; }
public UserModel(string username)
{
Username = username;
}

还有一个引导项目的FormsBootstrapper类,添加在根目录

        protected override void ConfigureApplicationContainer(TinyIoCContainer container)
{
// base.ConfigureApplicationContainer(container);
}
protected override void ConfigureRequestContainer(TinyIoCContainer container, NancyContext context)
{
base.ConfigureRequestContainer(container, context);
//这里我们将用户映射器注册为每个请求的单一实例。
//由于现在是每个请求, 我们可以注入一个请求范围
//数据库 "上下文" 或其他请求范围的服务。
container.Register<IUserMapper,UserDatabase>();
}
protected override void RequestStartup(TinyIoCContainer container, IPipelines pipelines, NancyContext context)
{
//base.RequestStartup(container, pipelines, context); //在请求启动时, 我们修改请求管线
//包括 forms 身份验证-在我们现在的请求中传递
//作用域的用户名映射程序。
//在这里传递的管道是特定于此请求的,
//因此, 我们可以添加 / 删除 / 更新的项目, 如下所示。
var formsAuthenConfiguration = new FormsAuthenticationConfiguration()
{
RedirectUrl="~/login",
UserMapper=container.Resolve<IUserMapper>()
};
FormsAuthentication.Enable(pipelines,formsAuthenConfiguration);
}

以上的后台逻辑是基本的写完了,接下里处理界面,在View是文件夹里面添加index,login,secure页面

页面就暂时这么处理,运行看看FormsDemo

最后的提醒别忘记里修改Web.config哦

这里声明一下,本来昨天博主要更新的,但是由于某些事情,没能及时更新

NancyFx 2.0的开源框架的使用-Forms的更多相关文章

  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的开源框架的使用-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. Dive in python Chapter3 实例

    def buildConnectionString(params): """Build a connection string from a dictionary Ret ...

  2. Jmeter-元件的作用域和执行顺序

    Jmeter有8类可执行的元件,包括:逻辑控制器.配置元件.定时器.前置处理器.取样器.后置处理器.断言和监听器. 测试计划和线程组不属于元件. 1)取样器(Sampler):不与其他元件发生交互作用 ...

  3. webpack快速掌握教程

    转载http://yijiebuyi.com/blog/46fb97b11fb8f4055e0b04d1cecb1f69.html #为什么用webpack 如果我们 前端 javascript 能像 ...

  4. 什么是测试开发工程师-google的解释

    什么是测试开发工程师-google的解释 “ 软件测试开发工程师[SET or Software Engineer in Test],和软件开发工程师一样是开发工程师,主要负责软件的可测试性.他们参与 ...

  5. 3.Java日志框架slf4j、jcl、jul、log4j1、log4j2、logback大总结

    一.slf4j.jcl.jul.log4j1.log4j2.logback JUL:JDK中的日志记录工具,也常称为JDKLog.jdk-logging. LOG4J1:一个具体的日志实现框架. LO ...

  6. WebService基础学习(二)—三要素

    一.Java中WebService规范      JAVA 中共有三种WebService 规范,分别是JAX-WS.JAX-RS.JAXM&SAAJ(废弃).   1.JAX-WS规范    ...

  7. 使用Jersey实现图片服务器与应用服务器分离

         现在模拟一下Jersey从客户端发送图片到服务器.   1.Tomcat准备 (1)解压一个新的Tomcat作为图片服务器,然后修改端口号(有3处).                (2)然 ...

  8. 使用IO流实现音频的剪切和拼接

    需求: 使用IO流将指定目录下的若干个音频文件的高潮部分,进行剪切,并重新拼接成一首新的音频文件 思路(以两首歌为例): 第一首歌有一个输入流对象bis1.第二首歌有一个输入流对象bis2,他们公用一 ...

  9. 02 Learning to Answer Yes/No

    Perceptron Learning Algorithm 感知器算法, 本质是二元线性分类算法,即用一条线/一个面/一个超平面将1,2维/3维/4维及以上数据集根据标签的不同一分为二. 算法确定后, ...

  10. JS常用特效方法总结

    1.按Ctrl提交 <body onkeydown="if(event.ctrlKey&&event.keyCode=='13') form1.submit.click ...