petshop使用最经典的三层结构,展现层,业务逻辑层,数据访问层。web层-->BLL(使用Model)-->DALFactory(通过IDAL)-->具体DAL实现层(oracle或ms sql)-->持久存储。
展现层使用了大量的用户控件,让页面设计更分散,而不是所有的HTML代码都放在一个文件中,造成页面代码的混乱。比如,首页就是用2个usercontrol整合的,只需在default.aspx的HTML代码中加入以下2个语句:
<%@ Register TagPrefix="PetsControl" TagName="Banner" Src="Controls/Banner.ascx" %>
<%@ Register TagPrefix="PetsControl" TagName="NavBarNoMenu" Src="Controls/NavBarNoMenu.ascx" %>
然后在该使用这个控件的地方使用如下代码:
<PetsControl:navbarnomenu id="header" hidecategorymenu="true" runat="server"></PetsControl:navbarnomenu>
对于应用和会话状态: petshop使用基于Form的认证模式:
<authentication mode="Forms">
<forms name="PetShopAuth" loginUrl="SignIn.aspx" protection="None" timeout="60"/>
</authentication>
其他的location定义了拒绝匿名访问的页面,点击这些页面时,用户如果没有登录系统会首先转到登录页面。
用户信息和用户的购物信息基本上是通过ProcessFlow中的AccountController.cs和CartController.cs实现的。
用户登录时会调用AccountController.cs的public bool ProcessLogin(string userId, string password)方法,登录成功后会通过HttpContext.Current.Session[ACCOUNT_KEY] = myAccountInfo在session中储存用户帐号信息。创建新帐号成功后同样会在session中储存用户帐号信息。同理,更新帐户信息会更新session,退出会清除session。
对于购物信息,也是存在于session中。存储购物车后会将购物车信息储存在session中。存储信用卡时会在session中保存信用卡信息,等等。
数据访问层:可以连接sqlServer和Oracle,分别用2个类实现同一个接口,以后如果要使用其他数据库,只需要增加一个类实现IDAL就可以了,这就是所谓的面向接口编程,遵循开闭原则。
在以后的设计中,一定要把这个当作一个框架来使用,尽量往这个方向靠。