成員管理
一、 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>
新聞熱點
疑難解答
圖片精選