程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> ASP.NET 2.0角色及成員管理

ASP.NET 2.0角色及成員管理

編輯:.NET實例教程

     成員管理
  一、 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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved