zoukankan      html  css  js  c++  java
  • 领域驱动设计案例:Tiny Library:用户界面

    工作繁忙,很久没有更新博客了。下面言归正传,简单介绍一下Tiny Library的用户界面实现。

    如前所述,Tiny Library采用ASP.NET MVC框架实现了基于浏览器的用户界面。回顾一下《业务逻辑与系统结构》一文,从层次架构图中我们可以清楚地看到,用户界面层是通过WCF Services与系统交互的。

    为了快速简单地实现Tiny Library,我只是简单地使用了ASP.NET MVC,因此没有对其做更深入的挖掘,有关ASP.NET MVC的更多知识,请朋友们自行上网搜索或阅读相关书籍。

    这里需要说明的问题有两点:用户认证与授权,以及MVC中的M。

    用户认证与授权(Authentication & Authorization)

    ASP.NET MVC采用基于Forms的认证机制(Forms Authentication),因此Tiny Library也继承了这种方式。事实上,使用ASP.NET MVC的这种认证机制,会在站点的App_Data目录下产生一个ASPNETDB.MDF的数据库文件,用来保存Authentication相关信息,比如某个用户注册了,就会在这个数据库中产生相关信息。然而,我们的Tiny Library也有一套自己的数据库,该库中需要保存用户的相关信息(比如Reader的名字等),目前我是在AccountController中,Register用户的时候,同时在Tiny Library中同步一条数据,代码如下:

    隐藏行号 复制代码 Register User
    1. MembershipCreateStatus createStatus = MembershipService.CreateUser(model.UserName, model.Password, model.Email);
      
    2. 
      
    3. if (createStatus == MembershipCreateStatus.Success)
      
    4. {
      
    5.     TinyLibraryServiceClient svcClient = new TinyLibraryServiceClient();
      
    6.     bool ret = svcClient.AddReader(new ReaderData
      
    7.     {
      
    8.         Id = Guid.NewGuid(),
      
    9.         Name = model.Name,
      
    10.         UserName = model.UserName
      
    11.     });
      
    12.     svcClient.Close();
      
    13.     if (ret)
      
    14.     {
      
    15.         FormsService.SignIn(model.UserName, false /* createPersistentCookie */);
      
    16.         return RedirectToAction("Index", "Home");
      
    17.     }
      
    18.     else
      
    19.     {
      
    20. 
      
    21.     }
      
    22. }
      
    23. else
      
    24. {
      
    25.     ModelState.AddModelError("", AccountValidation.ErrorCodeToString(createStatus));
      
    26. }
      
    27. 
      

    这样做其实很不保险,比如,如果在Tiny Library数据库中添加用户信息失败,那么虽然用户成功注册(提交ASPNETDB.MDF成功),也无法正常使用系统。当然,Tiny Library只是个演示系统,如果是在实际应用中,这个问题还需要通过其他途径解决。我目前没有想到万全之策,欢迎热心的朋友在本文的留言中给出建议。

    MVC中的M(Model)

    有不少使用ASP.NET MVC的朋友,总会将Domain Model带到用户界面层,然后直接将Domain Model中的实体用作MVC中的M。在Fowler的PoEAA一书的DTO一章已经说过,Domain Model是不能暴露给高层的,因此将Domain Model中的实体用于MVC是不合理的。

    其实如果你有了解过CQRS体系结构模式,你就会了解到,MVC中的M,应该是Presentation Model,这个Presentation Model与领域毫无关系,仅仅用于界面数据绑定。在MVC Web Application添加了WCF的Service Reference之后,当你创建View的时候,你就可以很方便地将客户端产生的Data Contract用作Data Class,如下:

    image

    其实,这里列出来的BookData、ReaderData和RegistrationData,就是Model。

    OK,用户界面就写这么些吧,也没有采用什么特别的技术,主要还是使用ASP.NET MVC上的这几个问题。有关ASP.NET MVC的内容,朋友们请自己查阅相关资料吧!

  • 相关阅读:
    java算法
    2012 要找回曾经的忘我的激情
    啊啊啊
    利用ORACLE JOB 模拟多线程应用
    有没有一种数据库叫思科
    且行好事,莫问前程
    女人浪漫的好点子
    What is the difference between interface and abstract class
    优秀是一种习惯
    C#判断ContextMenuStrip右键菜单的来源(从哪个控件弹出来的) (转载)
  • 原文地址:https://www.cnblogs.com/daxnet/p/1880949.html
Copyright © 2011-2022 走看看