ASP.NET 2.0角色及成员管理
点击次数:29 次 发布日期:2008-11-26 11:27:47 作者:源代码网
|
源代码网推荐 一、 Membership 类 : 创建和删除用户, 检索用户信 ,生成随机密码 , 登录验证 源代码网推荐 创建新用户:try { 源代码网推荐 Membership.CreateUser ("name", "password", "mail"); 源代码网推荐 } 源代码网推荐 catch (MembershipCreateUserException e) 源代码网推荐 { 源代码网推荐 // 失败 源代码网推荐 switch (e.StatusCode) 源代码网推荐 { 源代码网推荐 case MembershipCreateStatus.DuplicateUsername: 源代码网推荐 源代码网推荐 case MembershipCreateStatus.DuplicateEmail: 源代码网推荐 源代码网推荐 case MembershipCreateStatus.InvalidPassword: 源代码网推荐 源代码网推荐 default: 源代码网推荐 源代码网推荐 } 源代码网推荐 } 登录验证: 源代码网推荐 if (Membership.ValidateUser (UserName.Text, Password.Text)) 源代码网推荐 FormsAuthentication.RedirectFromLoginPage (UserName.Text, 源代码网推荐 RememberMe.Checked); 方法:CreateUser(创建用户) DeleteUser(删除用户) GeneratePassword(生产随即密码) GetAllUsers(得到用户) GetUser(查看某个用户) UpdateUser(修改用户) ValidateUser(验证是否成功) 源代码网推荐 二、 MembershipUser类: 源代码网推荐 描述在成员数据存储中单一的注册用户信息 源代码网推荐 包含了众多的属性来获取和设置用户信息 源代码网推荐 包含方法来检索、改变和重设密码 源代码网推荐 通过诸如GetUser 和CreateUser的属性返回值 源代码网推荐 属性:Comment CreationDate Email LastLoginDate LastPasswordChangedDate UserId UserName 源代码网推荐 方法: ChangePassword ChangePassword-QuestionAndAnswer GetPassword ResetPassword 源代码网推荐 挂起登录权限: 源代码网推荐 if (Membership.ValidateUser (UserName.Text, Password.Text)) { 源代码网推荐 MembershipUser user = Membership.GetUser (UserName.Text); 源代码网推荐 user.Comment = "0"; //记录登录次数 源代码网推荐 RedirectFromLoginPage (UserName.Text, RememberMe.Checked); 源代码网推荐 } 源代码网推荐 else { 源代码网推荐 MembershipUser user = Membership.GetUser (UserName.Text); 源代码网推荐 if (user != null) { 源代码网推荐 string count = Convert.ToInt32 (user.Comment) + 1; 源代码网推荐 user.Comment = count.ToString (); 源代码网推荐 } 源代码网推荐 }三 使用 SQL Server提供程序 源代码网推荐 <configuration> 源代码网推荐 <system.web> 源代码网推荐 <membership defaultProvider="AspNetSqlProvider" /> 源代码网推荐 </system.web> 源代码网推荐 </configuration> 更改提供程序配置: 源代码网推荐 <membership> 源代码网推荐 <providers> 源代码网推荐 <remove name="AspNetSqlProvider" /> 源代码网推荐 <add name="AspNetSqlProvider" 源代码网推荐 type="System.Web.Security.SqlMembershipProvider, System.Web, " 源代码网推荐 connectionStringName="RemoteSqlServer" 源代码网推荐 enablePasswordRetrieval="false" 源代码网推荐 enablePasswordReset="true" 源代码网推荐 requiresQuestionAndAnswer="false" 源代码网推荐 applicationName="/" 源代码网推荐 requiresUniqueEmail="false" 源代码网推荐 passwordFormat="Hashed" 源代码网推荐 description="Stores and retrieves membership data " 源代码网推荐 /> 源代码网推荐 </providers> 源代码网推荐 </membership>配置提供程序 源代码网推荐 成员提供程序支持许多配置选项,密码如何被存储 (明文, 散列, 加密)?密码是否允许被恢复?用户是否必须有一个唯一的e-mail地址?通过提供程序类属性来表现,在配置文件中进行初始化 源代码网推荐 四、角色管理 源代码网推荐 方法:AddUserToRole CreateRole DeleteRole GetRolesForUser(查看用户角色) GetUsersInRole IsUserInRole RemoveUserFromRole 源代码网推荐 创建新角色 源代码网推荐 if (!Roles.RoleExists ("Developers")) { 源代码网推荐 Roles.CreateRole ("Developers"); 源代码网推荐 } 增加用户到一个角色 源代码网推荐 string name = Membership.GetUser ().Username; 源代码网推荐 Roles.AddUserToRole (name, "Developers"); 配置Web.config启用角色 源代码网推荐 <configuration> 源代码网推荐 <system.web> 源代码网推荐 <roleManager enabled="true" /> 源代码网推荐 </system.web> 源代码网推荐 </configuration> 启用角色高速缓存 源代码网推荐 <configuration> 源代码网推荐 <system.web> 源代码网推荐 <roleManager enabled="true" cacheRolesInCookie="true" /> 源代码网推荐 <!-- Other roleManager attributes (and their defaults) include: 源代码网推荐 cookieName=".ASPXROLES" // Cookie name 源代码网推荐 cookieTimeout="30" // Cookie lifetime 源代码网推荐 cookiePath="/" // Cookie path 源代码网推荐 cookieRequireSSL="false" // Restrict cookie to SSL? 源代码网推荐 cookieSlidingExpiration="true" // Renew expiring cookies? 源代码网推荐 createPersistentCookie="false" // Issue persistent cookie? 源代码网推荐 cookieProtection="All" /> // Cookie protection level 源代码网推荐 --> 源代码网推荐 </system.web> 源代码网推荐 </configuration> 使用SQL Server提供程序 源代码网推荐 <configuration> 源代码网推荐 <system.web> 源代码网推荐 <roleManager enabled="true" defaultProvider="AspNetSqlRoleProvider" /> 源代码网推荐 </system.web> 源代码网推荐 </configuration> 源代码网推荐 错误提示: 源代码网推荐 密码最短长度为 7,其中必须包含以下非字母数字字符: 1 源代码网推荐 源代码网推荐 解决方案: 源代码网推荐 收到以上的消息主要是在创建用户的时候产生的,对于用Asp.net 网站管理工具的时候创建用户也会产生。 源代码网推荐 主要是密码输入不符合要求,要改变上面的规定时,主要有两种方法: 源代码网推荐 1.所有的站点都改变。 源代码网推荐 找到machine.config文件 源代码网推荐 源代码网推荐 <membership> 源代码网推荐 <providers> 源代码网推荐 <add name="AspNetSqlMembershipProvider" 源代码网推荐 type="System.Web.Security.SqlMembershipProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" 源代码网推荐 connectionStringName="LocalSqlServer" 源代码网推荐 enablePasswordRetrieval="false" 源代码网推荐 enablePasswordReset="true" 源代码网推荐 requiresQuestionAndAnswer="true" 源代码网推荐 applicationName="/" 源代码网推荐 requiresUniqueEmail="false" 源代码网推荐 passwordFormat="Hashed" 源代码网推荐 maxInvalidPasswordAttempts="5" 源代码网推荐 minRequiredPasswordLength="7" 源代码网推荐 minRequiredNonalphanumericCharacters="1" 源代码网推荐 passwordAttemptWindow="10" 源代码网推荐 passwordStrengthRegularExpression="" /> 源代码网推荐 </providers> 源代码网推荐 </membership> 源代码网推荐 里面有两个属性,一个是 minRequiredPasswordLength,意思是最长密码,默认为7另一个是minRequiredNonalphanumericCharacters,默认为1,意思是至少有一个非字母字符,只要把它改成0就可以了。 源代码网推荐 源代码网推荐 2.假如只是对某一个站点,只要修改web.config的值就ok了 源代码网推荐 修改如上,把上面的代码插入在<system.web>下面就ok了。 源代码网推荐 源代码网推荐 如要改成密码规则是"至少6个字符,而不用特殊字符的",如下: 源代码网推荐 (注:一定要加上 <remove name="AspNetSqlMembershipProvider" />,否则会提示"项“AspNetSqlMembershipProvider”已添加"的出错信息) 源代码网推荐 源代码网推荐 <membership> 源代码网推荐 <providers> 源代码网推荐 <remove name="AspNetSqlMembershipProvider" /> 源代码网推荐 <add name="AspNetSqlMembershipProvider" 源代码网推荐 type="System.Web.Security.SqlMembershipProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" 源代码网推荐 connectionStringName="LocalSqlServer" 源代码网推荐 enablePasswordRetrieval="false" 源代码网推荐 enablePasswordReset="true" 源代码网推荐 requiresQuestionAndAnswer="true" 源代码网推荐 applicationName="/" 源代码网推荐 requiresUniqueEmail="false" 源代码网推荐 passwordFormat="Hashed" 源代码网推荐 maxInvalidPasswordAttempts="5" 源代码网推荐 minRequiredPasswordLength="6" 源代码网推荐 minRequiredNonalphanumericCharacters="0" 源代码网推荐 passwordAttemptWindow="10" 源代码网推荐 passwordStrengthRegularExpression="" /> 源代码网推荐 </providers> 源代码网推荐 </membership> 源代码网推荐 http://blog.csdn.net/flylhf126/archive/2007/01/23/1490600.aspx 源代码网推荐 源代码网推荐 做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。 源代码网推荐 源代码网供稿. |
