# ASP.NET Web Pages - WebSecurity 對象
## 描述
**WebSecurity 對象**提供 ASP.NET Web Pages 應用程序的安全性和認證。
通過 WebSecurity 對象,您可以創建用戶帳戶,登錄和注銷用戶,重置或者更改密碼,以及其他更多與安全性相關的功能。
## WebSecurity 對象參考手冊 - 屬性
| 屬性 | 描述 |
| --- | --- |
| [CurrentUserId](prop-websecurity-currentuserid.html) | 獲取當前登錄用戶的 ID。 |
| [CurrentUserName](prop-websecurity-currentusername.html) | 獲取當前登錄用戶的名稱。 |
| [HasUserId](prop-websecurity-hasuserid.html) | 如果當前有用戶 ID,則返回 true。 |
| [IsAuthenticated](prop-websecurity-isauthenticated.html) | 如果當前用戶是登錄的,則返回 true。 |
## WebSecurity 對象參考手冊 - 方法
| 方法 | 描述 |
| --- | --- |
| [ChangePassword()](met-websecurity-changepassword.html) | 為指定的用戶更改密碼。 |
| [ConfirmAccount()](met-websecurity-confirmaccount.html) | 使用帳戶確認令牌確認帳戶。 |
| [CreateAccount()](met-websecurity-createaccount.html) | 創建一個新的用戶帳戶。 |
| [CreateUserAndAccount()](met-websecurity-createuserandaccount.html) | 創建一個新的用戶帳戶。 |
| [GeneratePasswordResetToken()](met-websecurity-generatepasswordresettoken.html) | 生成一個密碼重置令牌,可以在電子郵件中發送給用戶以便用戶可以重設密碼。 |
| [GetCreateDate()](met-websecurity-getcreatedate.html) | 獲取指定會員創建的時間。 |
| [GetPasswordChangeDate()](met-websecurity-getpasswordchangedate.html) | 獲取密碼變更的日期和時間。 |
| [GetUserId()](met-websecurity-getuserid.html) | 根據用戶名稱獲取用戶 ID。 |
| [InitializeDatabaseConnection()](met-websecurity-initializedatabaseconnection.html) | 初始化 WebSecurity 系統(數據庫)。 |
| [IsConfirmed()](met-websecurity-isconfirmed.html) | 檢查用戶是否已被確認。如果已確認,則返回 true。(例如,可通過電子郵件進行確認。) |
| [IsCurrentUser()](met-websecurity-iscurrentuser.html) | 檢查當前用戶的名稱是否與指定用戶名匹配。如果匹配,則返回 true。 |
| [Login()](met-websecurity-login.html) | 設置身份驗證令牌,登錄用戶。 |
| [Logout()](met-websecurity-logout.html) | 移除身份驗證令牌,注銷用戶。 |
| [RequireAuthenticatedUser()](met-websecurity-requireauthenticateduser.html) | 如果用戶未通過身份驗證,則設置 HTTP 狀態為 401(未經授權)。 |
| [RequireRoles()](met-websecurity-requireroles.html) | 如果當前用戶不是指定角色的成員,則設置 HTTP 狀態為 401(未經授權)。 |
| [RequireUser()](met-websecurity-requireuser.html) | 如果當前用戶不是指定用戶名的用戶,則設置 HTTP 狀態為 401(未經授權)。 |
| [ResetPassword()](met-websecurity-resetpassword.html) | 如果密碼重置令牌是有效的,改變用戶的密碼為新密碼。 |
| [UserExists()](met-websecurity-userexists.html) | 檢查指定的用戶是否存在。 |
## 技術數據
| 名稱 | 值 |
| --- | --- |
| Class | WebMatrix.WebData.WebSecurity |
| Namespace | WebMatrix.WebData |
| Assembly | WebMatrix.WebData.dll |
## 初始化 WebSecurity 數據庫
如果您想在您的代碼中使用 WebSecurity 對象,首先您必須創建或者初始化 WebSecurity 數據庫。
在您的 Web 根目錄下,創建一個名為 **_AppStart.cshtml** 的頁面(如果已存在,則直接編輯頁面)。
將下面的代碼復制到文件中:
## \_AppStart.cshtml
```
@{
WebSecurity.InitializeDatabaseConnection("Users", "UserProfile", "UserId", "Email", true);
}
```
上面的代碼將在每次網站(應用程序)啟動時運行。它初始化了 WebSecurity 數據庫。
**"Users"** 是 WebSecurity 數據庫(Users.sdf)的名稱。
**"UserProfile"** 是包含用戶配置信息的數據庫表的名稱。
**"UserId"** 是包含用戶 ID(主鍵)的列的名稱。
**"Email"** 是包含用戶名的列的名稱。
最后一個參數 **true** 是一個布爾值,表示如果用戶配置表和會員表不存在,則會自動創建表。如果不想自動創建表,應設置參數為 **false**。
> 
> 雖然 **true** 表示自動創建數據庫 **表**,但是數據庫不會被自動創建。所以數據庫必須存在。 |
## WebSecurity 數據庫
**UserProfile** 表為每個用戶創建保存一條記錄,用戶 ID(主鍵)和用戶名字(email):
| UserId | Email |
| --- | --- |
| 1 | john@johnson.net |
| 2 | peter@peterson.com |
| 3 | lars@larson.eut |
**Membership** 表包含會員信息,比如用戶是什么時候創建的,該會員是否已認證,會員是什么時候認證的,等等。
具體如下所示(一些列不顯示):
| User Id | Create Date | Confirmation Token | Is Confirmed | Last Password Failure | Password | Password Change |
| --- | --- | --- | --- | --- | --- | --- |
| 1 | 12.04.2012 16:12:17 | NULL | True | NULL | AFNQhWfy.... | 12.04.2012 16:12:17 |
注釋:如果您想看到所有的列和內容,請打開數據庫,看看里邊的每個表。
## 簡單的會員配置
在您使用 WebSecurity 對象時,如果您的站點沒有配置使用 ASP.NET Web Pages 會員系統 **SimpleMembership**,可能會報錯。
如果托管服務提供商的服務器的配置與您本地服務器的配置不同,也可能會報錯。為了解決這個問題,請在網站的 Web.config 文件中添加以下元素:
<appSettings>
<add key="enableSimpleMembership" value="true" />
</appSettings>
- C# 基礎
- C# 簡介
- C# 環境
- C# 程序結構
- C# 基本語法
- C# 數據類型
- C# 類型轉換
- C# 變量
- C# 常量
- C# 運算符
- C# 判斷
- C# 循環
- C# 封裝
- C# 方法
- C# 可空類型(Nullable)
- C# 數組(Array)
- C# 字符串(String)
- C# 結構(Struct)
- C# 枚舉(Enum)
- C# 類(Class)
- C# 繼承
- C# 多態性
- C# 運算符重載
- C# 接口(Interface)
- C# 命名空間(Namespace)
- C# 預處理器指令
- C# 正則表達式
- C# 異常處理
- C# 文件的輸入與輸出
- C# 高級
- C# 特性(Attribute)
- C# 反射(Reflection)
- C# 屬性(Property)
- C# 索引器(Indexer)
- C# 委托(Delegate)
- C# 事件(Event)
- C# 集合(Collection)
- C# 泛型(Generic)
- C# 匿名方法
- C# 不安全代碼
- C# 多線程
- ASP.NET 簡介
- Web Pages 教程
- ASP.NET Web Pages - 教程
- ASP.NET Web Pages - 添加 Razor 代碼
- ASP.NET Web Pages - 頁面布局
- ASP.NET Web Pages - 文件夾
- ASP.NET Web Pages - 全局頁面
- ASP.NET Web Pages - HTML 表單
- ASP.NET Web Pages - 對象
- ASP.NET Web Pages - 文件
- ASP.NET Web Pages - 幫助器
- ASP.NET Web Pages - WebGrid 幫助器
- ASP.NET Web Pages - Chart 幫助器
- ASP.NET Web Pages - WebMail 幫助器
- ASP.NET Web Pages - PHP
- ASP.NET Web Pages - 發布網站
- Razor 教程
- ASP.NET Razor - 標記
- ASP.NET Razor - C# 和 VB 代碼語法
- ASP.NET Razor - C# 變量
- ASP.NET Razor - C# 循環和數組
- ASP.NET Razor - C# 邏輯條件
- ASP.NET Razor - VB 變量
- ASP.NET Razor - VB 循環和數組
- ASP.NET Razor - VB 邏輯條件
- MVC 教程
- ASP.NET MVC 教程
- ASP.NET MVC - Internet 應用程序
- ASP.NET MVC - 應用程序文件夾
- ASP.NET MVC - 樣式和布局
- ASP.NET MVC - 控制器
- ASP.NET MVC - 視圖
- ASP.NET MVC - SQL 數據庫
- ASP.NET MVC - 模型
- ASP.NET MVC - 安全
- ASP.NET MVC - HTML 幫助器
- ASP.NET MVC - 發布網站
- Web Forms 教程
- ASP.NET Web Forms - 教程
- ASP.NET Web Forms - HTML 頁面
- ASP.NET Web Forms - 服務器控件
- ASP.NET Web Forms - 事件
- ASP.NET Web Forms - HTML 表單
- ASP.NET Web Forms - 維持 ViewState
- ASP.NET Web Forms - TextBox 控件
- ASP.NET Web Forms - Button 控件
- ASP.NET Web Forms - 數據綁定
- ASP.NET Web Forms - ArrayList 對象
- ASP.NET Web Forms - Hashtable 對象
- ASP.NET Web Forms - SortedList 對象
- ASP.NET Web Forms - XML 文件
- ASP.NET Web Forms - Repeater 控件
- ASP.NET Web Forms - DataList 控件
- ASP.NET Web Forms - 數據庫連接
- ASP.NET Web Forms - 母版頁
- ASP.NET Web Forms - 導航
- Web Pages 參考手冊
- ASP.NET Web Pages - 類
- ASP.NET Web Pages - WebSecurity 對象
- ASP.NET Web Pages - Database 對象
- ASP.NET Web Pages - WebMail 對象
- ASP.NET Web Pages - 更多幫助器
- MVC - 參考手冊
- Web Forms 參考手冊
- ASP.NET Web Forms - HTML 服務器控件
- ASP.NET Web Forms - Web 服務器控件
- ASP.NET Web Forms - Validation 服務器控件
- 免責聲明