CreateUserWizard控件

1、采取扩展CreateUserWizard控件,我们可以使用它的模版列,此时需要注意的是:用户名,密码,提示问题,提示问题答案,Email,他们的ID一定要分别是username,Password,Question,Answer,Email否则会出错,而且此时验证控件均不能使用。怀疑是IDE的一个Bug。   如下所示,我们定义好的样式应当是:

<WizardSteps> <asp:CreateUserWizardStep runat="server"> 自定义代码部分<ContentTemplate> </ContentTemplate> </asp:CreateUserWizardStep> </WizardSteps> 代码部分: protected void CreateUserWizard1_CreatedUser(object sender, EventArgs e) {  //由于系统会自动给们建立基本的信息表,所以我们只需要对profile或者membershipinfo标进行修改即可。     Roles.AddUserToRole(CreateUserWizard1.UserName, "shop");   //添加用户到相应的组   ProfileCommon p = (ProfileCommon)ProfileCommon.Create(CreateUserWizard1.UserName, true);   p. QQ = ((TextBox)CreateUserWizard1.CreateUserStep.ContentTemplateContainer.FindControl("QQ")).Text.Trim();  p.address= ((TextBox)CreateUserWizard1.CreateUserStep.ContentTemplateContainer.FindControl("address")).Text.Trim();     p.phone = ((TextBox)CreateUserWizard1.CreateUserStep.ContentTemplateContainer.FindControl("phone")).Text.Trim(); p.Save();//保存所作修改 }

  2、采取自己写UI,个人推荐使用这种方法。灵活性比较大,而且可以使用2005强大的验证控件。   页面部分比较简单略过不再陈述。下面详细介绍一下代码部分。   此时我们需要使用membership的CreateUser()方法。语法我们就不再介绍。他会根据建立用户的结果返回成一个MembershipCreateStatus枚举类,它详细的包含了所有建立用户不成功的错误信息。我们只需要根据他的值,就可以返回给界面相应的提示,如:用户名已经存在,电子邮件已经存在等等。   对于自定义用户信息部分我们仍然可以采取profile或者自定义membershipinfo表的方法。   列出profile建立用户的方法。SQL语句比较简单,略过不写。

protected void Button1_Click(object sender, EventArgs e)  {  MembershipCreateStatus status;   MembershipUser newUser = Membership.CreateUser(username.Text.Trim(), Password.Text.Trim(),  Email.Text.Trim(), Question.Text.Trim(), Answer.Text.Trim(), true, out status);  //使用membership建立用户,并把建立结果返回给MembershipCreateStatus    if (newUser == null)//没有新用户,则意味着出错。    {   GetErrorMessage(status);   //调用GetErrorMessage函数,返回详细错误信息    } else {     Roles.AddUserToRole(newUser.UserName, "jiancai");    //添加用户到相应组 ProfileCommon    p = (ProfileCommon)ProfileCommon.Create(newUser.UserName, true);    p.QQ = QQ.Text.Trim();    p.address= address.Text.Trim();    p.phone= phone.Text.Trim();    p.Save();   }  } public void GetErrorMessage(MembershipCreateStatus status) {  switch (status)    {    case MembershipCreateStatus.DuplicateUserName: DisplayAlert("当前用户已经存在,请重新选择");     break;     //其余各种错误信息,请查看MSDN的MembershipCreateStatus枚举类。     default: DisplayAlert("注册00000000用户失败,请检查您的用户名,密码等信息");     break;    } }

  个人见解:采取profile的方法,比较方便,由于profile 是强类型,可以通过智能感知功能减少代码的输入量。采取自定义数据表的方法,需要输入大量的sql语句,但是查询速度比较快,性能比较强,由于Roles.GetUsersInRole()方法无法分页读取数据,只能一次性读出来所有数据,而自写SQL 语句可以很方便的根分页结合起来。随着用户量的增多,故不推荐profile方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值