6.4  ASP.NET 2.0新特性

由于PetShop 4.0是基于.NET Framework 2.0平台开发的电子商务系统,因而它在表示层也引入了许多ASP.NET 2.0的新特性,例如MemberShip、Profile、Master Page、登录控件等特性。接下来,我将结合PetShop 4.0的设计分别介绍它们的实现。

6.4.1  Profile特性

Profile提供的功能是针对用户的个性化服务。在ASP.NET 1.x版本时,我们可以利用Session、Cookie等方法来存储用户的状态信息。然而Session对象是具有生存期的,一旦生存期结束,该对象保留的值就会失效。Cookie将用户信息保存在客户端,它具有一定的安全隐患,一些重要的信息不能存储在Cookie中。一旦客户端禁止使用Cookie,则该功能就将失去应用的作用。

Profile的出现解决了如上的烦恼,它可以将用户的个人化信息保存在指定的数据库中。ASP.NET 2.0的Profile功能默认支持Access数据库和SQL Server数据库,如果需要支持其他数据库,可以编写相关的ProfileProvider类。Profile对象是强类型的,我们可以为用户信息建立属性,以PetShop 4.0为例,它建立了ShoppingCart、WishList和AccountInfo属性。

由于Profile功能需要访问数据库,因而在数据访问层(DAL)定义了和Product等数据表相似的模块结构。首先定义了一个IProfileDAL接口模块,包含了接口IPetShopProfileProvider:

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°public interface IPetShopProfileProvider 

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° AddressInfo GetAccountInfo(string userName, string appName);   

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° void SetAccountInfo(int uniqueID, AddressInfo addressInfo);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° IList<CartItemInfo> GetCartItems(string userName, string appName, 

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°bool isShoppingCart);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° void SetCartItems(int uniqueID, ICollection<CartItemInfo> cartItems, 

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°bool isShoppingCart);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° void UpdateActivityDates(string userName, bool activityOnly, string appName);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° int GetUniqueID(string userName, bool isAuthenticated, bool ignoreAuthenticationType,

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° string appName);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° int CreateProfileForUser(string userName, bool isAuthenticated, string appName);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° IList<string> GetInactiveProfiles(int authenticationOption, 

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°DateTime userInactiveSinceDate, string appName);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° bool DeleteProfile(string userName, string appName);   

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° IList<CustomProfileInfo> GetProfileInfo(int authenticationOption, 

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°string usernameToMatch, DateTime userInactiveSinceDate, string appName, 

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°out int totalRecords);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°}

因为PetShop 4.0版本分别支持SQL Server和Oracle数据库,因而它分别定义了两个不同的PetShopProfileProvider类,实现IPetShopProfileProvider接口,并放在两个不同的模块SQLProfileDAL和OracleProfileDAL中。具体的实现请参见PetShop 4.0的源代码。

同样的,PetShop 4.0为Profile引入了工厂模式,定义了模块ProfileDALFActory,工厂类DataAccess的定义如下:

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°public sealed class DataAccess petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    private static readonly string profilePath = ConfigurationManager.AppSettings["ProfileDAL"];

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    public static PetShop.IProfileDAL.IPetShopProfileProvider CreatePetShopProfileProvider() petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° string className = profilePath + ".PetShopProfileProvider";

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° return (PetShop.IProfileDAL.IPetShopProfileProvider)Assembly.Load(profilePath).CreateInstance(className);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°}

在业务逻辑层(BLL)中,单独定义了模块Profile,它添加了对BLL、IProfileDAL和ProfileDALFactory模块的程序集。在该模块中,定义了密封类PetShopProfileProvider,它继承自System.Web.Profile.ProfileProvider类,该类作为Profile的Provider基类,用于在自定义配置文件中实现相关的配置文件服务。在PetShopProfileProvider类中,重写了父类ProfileProvider中的一些方法,例如Initialize()、GetPropertyValues()、SetPropertyValues()、DeleteProfiles()等方法。此外,还为ShoppingCart、WishList、AccountInfo属性提供了Get和Set方法。至于Provider的具体实现,则调用工厂类DataAccess创建的具体类型对象,如下所示:

private static readonly IPetShopProfileProvider dal = DataAccess.CreatePetShopProfileProvider();

定义了PetShop.Profile.PetShopProfileProvider类后,才可以在web.config配置文件中配置如下的配置节:

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°<profile automaticSaveEnabled="false" defaultProvider="ShoppingCartProvider">

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° <providers>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  <add name="ShoppingCartProvider" connectionStringName="SQLProfileConnString" type="PetShop.Profile.PetShopProfileProvider" applicationName=".NET Pet Shop 4.0"/>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  <add name="WishListProvider" connectionStringName="SQLProfileConnString" type="PetShop.Profile.PetShopProfileProvider" applicationName=".NET Pet Shop 4.0"/>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  <add name="AccountInfoProvider" connectionStringName="SQLProfileConnString" type="PetShop.Profile.PetShopProfileProvider" applicationName=".NET Pet Shop 4.0"/>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° </providers>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° <properties>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  <add name="ShoppingCart" type="PetShop.BLL.Cart" allowAnonymous="true" provider="ShoppingCartProvider"/>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  <add name="WishList" type="PetShop.BLL.Cart" allowAnonymous="true" provider="WishListProvider"/>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  <add name="AccountInfo" type="PetShop.Model.AddressInfo" allowAnonymous="false" provider="AccountInfoProvider"/>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° </properties>

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°</profile>

在配置文件中,针对ShoppingCart、WishList和AccountInfo(它们的类型分别为PetShop.BLL.Cart、PetShop.BLL.Cart、PetShop.Model.AddressInfo)属性分别定义了ShoppingCartProvider、WishListProvider、AccountInfoProvider,它们的类型均为PetShop.Profile.PetShopProfileProvider类型。至于Profile的信息究竟是存储在何种类型的数据库中,则由以下的配置节决定:

<add key="ProfileDAL" value="PetShop.SQLProfileDAL"/>

而键值为ProfileDAL的值,正是Profile的工厂类PetShop.ProfileDALFactory.DataAccess在利用反射技术创建IPetShopProfileProvider类型对象时获取的。

在表示层中,可以利用页面的Profile属性访问用户的个性化属性,例如在ShoppingCart页面的codebehind代码ShoppingCart.aspx.cs中,调用Profile的ShoppingCart属性:

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°public partial class ShoppingCart : System.Web.UI.Page petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    protected void Page_PreInit(object sender, EventArgs e) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°        if (!IsPostBack) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            string itemId = Request.QueryString["addItem"];

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            if (!string.IsNullOrEmpty(itemId)) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                Profile.ShoppingCart.Add(itemId);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                Profile.Save();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                // Redirect to prevent duplictations in the cart if user hits "Refresh"

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                Response.Redirect("~/ShoppingCart.aspx", true);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°        }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°}

在上述的代码中,Profile属性的值从何而来?实际上,在我们为web.config配置文件中对Profile进行配置后,启动Web应用程序,ASP.NET会根据该配置文件中的相关配置创建一个ProfileCommon类的实例。该类继承自System.Web.Profile.ProfileBase类。然后调用从父类继承来的GetPropertyValue和SetPropertyValue方法,检索和设置配置文件的属性值。然后,ASP.NET将创建好的ProfileCommon实例设置为页面的Profile属性值。因而,我们可以通过智能感知获取Profile的ShoppingCart属性,同时也可以利用ProfileCommon继承自ProfileBase类的Save()方法,根据属性值更新Profile的数据源。

6.4.2  Membership特性

PetShop 4.0并没有利用Membership的高级功能,而是直接让Membership特性和ASP.NET 2.0新增的登录控件进行绑定。由于.NET Framework 2.0已经定义了针对SQL Server的SqlMembershipProvider,因此对于PetShop 4.0而言,实现Membership比之实现Profile要简单,仅仅需要为Oracle数据库定义MembershipProvider即可。在PetShop.Membership模块中,定义了OracleMembershipProvider类,它继承自System.Web.Security.MembershipProvider抽象类。

OracleMembershipProvider类的实现具有极高的参考价值,如果我们需要定义自己的MembershipProvider类,可以参考该类的实现。

事实上OracleMemberShip类的实现并不复杂,在该类中,主要是针对用户及用户安全而实现相关的行为。由于在父类MembershipProvider中,已经定义了相关操作的虚方法,因此我们需要作的是重写这些虚方法。由于与Membership有关的信息都是存储在数据库中,因而OracleMembershipProvider与SqlMembershipProvider类的主要区别还是在于对数据库的访问。对于SQL Server而言,我们利用aspnet_regsql工具为Membership建立了相关的数据表以及存储过程。也许是因为知识产权的原因,Microsoft并没有为Oracle数据库提供类似的工具,因而需要我们自己去创建membership的数据表。此外,由于没有创建Oracle数据库的存储过程,因而OracleMembershipProvider类中的实现是直接调用SQL语句。以CreateUser()方法为例,剔除那些繁杂的参数判断与安全性判断,SqlMembershipProvider类的实现如下:

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°public override MembershipUser CreateUser(string username, string password, string email, string passwordQuestion, string passwordAnswer, bool isApproved, object providerUserKey, out MembershipCreateStatus status)

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      MembershipUser user1;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      //前面的代码略;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      try

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            SqlConnectionHolder holder1 = null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            try

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  holder1 = SqlConnectionHelper.GetConnection(this._sqlConnectionString, true);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  this.CheckSchemaVersion(holder1.Connection);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  DateTime time1 = this.RoundToSeconds(DateTime.UtcNow);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  SqlCommand command1 = new SqlCommand("dbo.aspnet_Membership_CreateUser", holder1.Connection);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.CommandTimeout = this.CommandTimeout;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.CommandType = CommandType.StoredProcedure;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@ApplicationName", SqlDbType.NVarChar, this.ApplicationName));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@UserName", SqlDbType.NVarChar, username));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@Password", SqlDbType.NVarChar, text2));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@PasswordSalt", SqlDbType.NVarChar, text1));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@Email", SqlDbType.NVarChar, email));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@PasswordQuestion", SqlDbType.NVarChar, passwordQuestion));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@PasswordAnswer", SqlDbType.NVarChar, text3));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@IsApproved", SqlDbType.Bit, isApproved));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@UniqueEmail", SqlDbType.Int, this.RequiresUniqueEmail ? 1 : 0));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@PasswordFormat", SqlDbType.Int, (int) this.PasswordFormat));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(this.CreateInputParam("@CurrentTimeUtc", SqlDbType.DateTime, time1));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  SqlParameter parameter1 = this.CreateInputParam("@UserId", SqlDbType.UniqueIdentifier, providerUserKey);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  parameter1.Direction = ParameterDirection.InputOutput;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(parameter1);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  parameter1 = new SqlParameter("@ReturnValue", SqlDbType.Int);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  parameter1.Direction = ParameterDirection.ReturnValue;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.Parameters.Add(parameter1);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  command1.ExecuteNonQuery();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  int num3 = (parameter1.Value != null) ? ((int) parameter1.Value) : -1;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  if ((num3 < 0) || (num3 > 11))

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                        num3 = 11;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  status = (MembershipCreateStatus) num3;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  if (num3 != 0)

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                        return null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  providerUserKey = new Guid(command1.Parameters["@UserId"].Value.ToString());

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  time1 = time1.ToLocalTime();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  user1 = new MembershipUser(this.Name, username, providerUserKey, email, passwordQuestion, null, isApproved, false, time1, time1, time1, time1, new DateTime(0x6da, 1, 1));

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            finally

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  if (holder1 != null)

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                        holder1.Close();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                        holder1 = null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°                  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      catch

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°            throw;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°      return user1;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°}

代码中,aspnet_Membership_CreateUser为aspnet_regsql工具为membership创建的存储过程,它的功能就是创建一个用户。

OracleMembershipProvider类中对CreateUser()方法的定义如下:

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°public override MembershipUser CreateUser(string username, string password, string email, string passwordQuestion, string passwordAnswer, bool isApproved, object userId, out MembershipCreateStatus status) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    //前面的代码略;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° //Create connection

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° OracleConnection connection = new OracleConnection(OracleHelper.ConnectionStringMembership);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° connection.Open();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° OracleTransaction transaction = connection.BeginTransaction(IsolationLevel.ReadCommitted);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° try petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  DateTime dt = DateTime.Now;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  bool isUserNew = true;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  // Step 1: Check if the user exists in the Users table: create if not    

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  int uid = GetUserID(transaction, applicationId, username, true, false, dt, out isUserNew);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(uid == 0) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{ // User not created successfully!

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   status = MembershipCreateStatus.ProviderError;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   return null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  // Step 2: Check if the user exists in the Membership table: Error if yes.

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(IsUserInMembership(transaction, uid)) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   status = MembershipCreateStatus.DuplicateUserName;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   return null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  // Step 3: Check if Email is duplicate

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(IsEmailInMembership(transaction, email, applicationId)) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   status = MembershipCreateStatus.DuplicateEmail;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   return null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  // Step 4: Create user in Membership table     

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  int pFormat = (int)passwordFormat;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(!InsertUser(transaction, uid, email, pass, pFormat, salt, "", "", isApproved, dt)) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   status = MembershipCreateStatus.ProviderError;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   return null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  // Step 5: Update activity date if user is not new

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(!isUserNew) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   if(!UpdateLastActivityDate(transaction, uid, dt)) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    status = MembershipCreateStatus.ProviderError;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°    return null;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  status = MembershipCreateStatus.Success;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  return new MembershipUser(this.Name, username, uid, email, passwordQuestion, null, isApproved, false, dt, dt, dt, dt, DateTime.MinValue);

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° catch(Exception) petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(status == MembershipCreateStatus.Success)

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   status = MembershipCreateStatus.ProviderError;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  throw;

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° finally petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°{

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  if(status == MembershipCreateStatus.Success)

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   transaction.Commit();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  else

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°   transaction.Rollback();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  connection.Close();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°  connection.Dispose();

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness° }

petshop4.0 详解之七(PetShop表示层设计)  - °嶶凉°昜祥。ノ - °昜_祥°loneliness°}

posted on 2009-07-13 01:29  阿C's  阅读(177)  评论(0编辑  收藏  举报