Asp.Mvc 2.0實(shí)現(xiàn)用戶登錄與注銷功能實(shí)例講解(2)
這一節(jié)講解下ASP.MVC 2.0的用戶登錄與注銷功能,先講登錄,后說(shuō)注銷。我們這個(gè)系列講的用戶登錄方式都是FORM表單驗(yàn)證方式。在講之前先給大家說(shuō)下<%:%>的功能,<%:%>與<%=%>功能一樣,用來(lái)動(dòng)態(tài)輸出內(nèi)容。
一、登錄
1. 建立MODEL
登錄的時(shí)候,我們一般只要驗(yàn)證用戶名和密碼,還有是否保存登錄COOKIE,所以我們建立一個(gè)MODEL登錄類,只需包括3個(gè)字段就可以。
/// <summary>
/// 用戶登錄MODEL
/// </summary>
public class Login
{
/// <summary>
/// 用戶名
/// </summary>
[DisplayName("用戶名")]
public string UserName
{
get;
set;
}
/// <summary>
/// 密碼
/// </summary>
[DisplayName("密碼")]
public string UserPwd
{
get;
set;
}
/// <summary>
/// 是否保存COOKIE
/// </summary>
[DisplayName("記住我")]
public bool RememberMe
{
get;
set;
} 2.建立VIEW頁(yè)面
同樣登錄的VIEW頁(yè)面,同樣建立一個(gè)強(qiáng)類型的頁(yè)面,之所以喜歡建立強(qiáng)類型的頁(yè)面,是因?yàn)轫?yè)面和MODEL相關(guān)聯(lián),在頁(yè)面中直接可以使用MODEL。此時(shí)頁(yè)面的視圖數(shù)據(jù)類應(yīng)選擇MvcLogin.Models.Login。
<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<MvcLogin.Models.Login>" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Login</title>
</head>
<body>
<div style="font-size:15pt;color:Red;">
<%if (ViewData["msg"] != null)
{%>
<%:ViewData["msg"].ToString()%>
<%} %>
</div>
<div>
<%Html.BeginForm();%>
<table>
<tr>
<td></td>
<td>用戶登錄</td>
</tr>
<tr>
<td><%:Html.LabelFor(m=>m.UserName) %></td>
<td><%:Html.TextBoxFor(m=>m.UserName)%></td>
</tr>
<tr>
<td><%:Html.LabelFor(m=>m.UserPwd) %></td>
<td><%:Html.PasswordFor(m=>m.UserPwd) %></td>
</tr>
<tr>
<td><%:Html.LabelFor(m=>m.RememberMe) %></td>
<td><%:Html.CheckBoxFor(m=>m.RememberMe) %></td>
</tr>
<tr>
<td></td>
<td><input type="submit" value="登錄" /></td>
</tr>
</table>
<%Html.EndForm(); %>
</div>
</body>
</html>
Html.CheckBoxFor用來(lái)生成一個(gè)復(fù)選框按鈕
3.建立controller
同樣我們?cè)赾ontroller中建立兩個(gè)login方法,一個(gè)用來(lái)展現(xiàn)頁(yè)面,一個(gè)用來(lái)點(diǎn)擊登錄按鈕后判斷用戶名和密碼
public ActionResult Login()
{
return View();
}
[HttpPost]
public ActionResult Login(Models.Login model)
{
if (new Models.SqlHelper().UserLogin(model))
{
//如果用戶名存在,轉(zhuǎn)向主頁(yè)
FormsService.SignIn(model.UserName,model.RememberMe);
return RedirectToAction("index");
}
else
{
//登錄失敗,轉(zhuǎn)向登錄頁(yè)面
ViewData["msg"] = "登錄失敗";
return View(model);
}
}
第二個(gè)Login方法前面有HTTPPOST屬性,所以只能接受POST請(qǐng)求
4.SQLHELPER中添加判斷用戶名和密碼的方法
/// <summary>
/// 判斷用戶登錄是否成功
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public bool UserLogin(Login model)
{
strUserExist = string.Format(strUserExist, model.UserName, model.UserPwd);
SqlConnection con = new SqlConnection(conStr);
con.Open();
SqlCommand cmd = new SqlCommand(strUserExist, con);
SqlDataAdapter adp = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
adp.Fill(ds);
con.Close();
if (ds != null && ds.Tables[0].Rows.Count > 0)
{
return true;
}
return false;
}
5.運(yùn)行登錄頁(yè)面
此時(shí)我們?cè)陧?yè)面中輸入U(xiǎn)RL,就會(huì)轉(zhuǎn)向登錄頁(yè)面,
效果如下:

點(diǎn)擊登錄,登錄成功后轉(zhuǎn)向首頁(yè),登錄失敗返回本頁(yè)面,并顯示提示信息。
點(diǎn)擊登錄的時(shí)候,是POST提交方式,會(huì)調(diào)用publicActionResult Login(Models.Login model)方法。
登錄失敗頁(yè)面如下

登錄成功頁(yè)面如下

二.注銷
登錄成功后,轉(zhuǎn)向首頁(yè),在首頁(yè)上我們會(huì)生成注銷連接。
<p style="font-size:15pt; color:Red;">
<%if (Request.IsAuthenticated)
{%>
歡迎您<%:Page.User.Identity.Name%>!
<%:Html.ActionLink("注銷", "LoginOff")%>
<%}
else
{%>
<%:Html.ActionLink("登錄", "Login")%>
<%} %>
</p>
這里介紹下Html.ActionLink方法,Html.ActionLink用來(lái)生成一個(gè)鏈接,第一個(gè)參數(shù)代表鏈接的問題,第二個(gè)參數(shù)代表的是actionname,可以理解為鏈接的頁(yè)面。
由以上代碼可以看出,注銷鏈接指向LoginoFF.,也就是controller中的loginoff action方法,所以我們?cè)赾ontroller中添加一個(gè)一個(gè)loginoff方法,執(zhí)行完loginoff方法后,會(huì)轉(zhuǎn)向INDEX首頁(yè)
/// <summary>
/// 用戶注銷
/// </summary>
/// <returns></returns>
public ActionResult LoginOff()
{
FormsService.SignOut();
return RedirectToAction("index");
}
以上就是Asp.Mvc 2.0實(shí)現(xiàn)用戶登錄與注銷功能實(shí)例講解,大家可以在自己的網(wǎng)站上進(jìn)行實(shí)踐了,希望在此基礎(chǔ)上可以有所創(chuàng)新和完善。
- ASP.NET MVC5網(wǎng)站開發(fā)之登錄、驗(yàn)證和注銷管理員篇1(六)
- ASP.NET?MVC5網(wǎng)站開發(fā)用戶登錄、注銷(五)
- ASP.NET登錄注冊(cè)頁(yè)面實(shí)現(xiàn)
- 一款經(jīng)典的ajax登錄頁(yè)面 后臺(tái)asp.net
- asp.net jQuery Ajax用戶登錄功能的實(shí)現(xiàn)
- asp.net利用cookie保存用戶密碼實(shí)現(xiàn)自動(dòng)登錄的方法
- 一個(gè)簡(jiǎn)單的asp.net 單點(diǎn)登錄實(shí)現(xiàn)
- [Asp.Net MVC4]驗(yàn)證用戶登錄實(shí)現(xiàn)實(shí)例
- ASP.NET實(shí)現(xiàn)QQ、微信、新浪微博OAuth2.0授權(quán)登錄
相關(guān)文章
.NET 與樹莓派WS28XX 燈帶的顏色漸變動(dòng)畫效果的實(shí)現(xiàn)
所謂顏色漸變動(dòng)畫,首先,你要確定兩種顏色——起始色和最終色,比如從綠色變成紅色,綠色是起始,紅色是終點(diǎn)。這篇文章主要介紹了.NET 與樹莓派WS28XX 燈帶的顏色漸變動(dòng)畫,需要的朋友可以參考下2021-12-12
詳解免費(fèi)開源的DotNet二維碼操作組件ThoughtWorks.QRCode(.NET組件介紹之四)
本篇文章主要介紹了免費(fèi)開源的DotNet二維碼操作組件ThoughtWorks.QRCode,非常具有實(shí)用價(jià)值,有興趣的同學(xué)可以來(lái)了解一下。2016-12-12
Asp.net開發(fā)之webform圖片水印和圖片驗(yàn)證碼的實(shí)現(xiàn)方法
這篇文章主要介紹了Asp.net開發(fā)之webform圖片水印和圖片驗(yàn)證碼的實(shí)現(xiàn)方法,實(shí)現(xiàn)思路分為前后臺(tái)代碼和效果展示,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-10-10
.Net?core?Blazor+自定義日志提供器實(shí)現(xiàn)實(shí)時(shí)日志查看器的原理解析
我們經(jīng)常遠(yuǎn)程連接服務(wù)器去查看日志,比較麻煩,如果直接訪問項(xiàng)目的某個(gè)頁(yè)面就能實(shí)時(shí)查看日志就比較奈斯了,結(jié)合blazor實(shí)現(xiàn)了基本效果,這篇文章主要介紹了.Net?core?Blazor+自定義日志提供器實(shí)現(xiàn)實(shí)時(shí)日志查看器,需要的朋友可以參考下2022-10-10
基于.NET?7?的?QUIC?實(shí)現(xiàn)?Echo?服務(wù)的詳細(xì)過程
這篇文章主要介紹了基于.NET?7?的?QUIC實(shí)現(xiàn)Echo服務(wù),下面的內(nèi)容中,我會(huì)介紹如何在.NET?中使用?Quic,文中結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-11-11
使用updatepanel局部刷新實(shí)現(xiàn)注冊(cè)時(shí)對(duì)用戶名的檢測(cè)示例
這篇文章主要介紹了使用updatepanel局部刷新實(shí)現(xiàn)注冊(cè)時(shí)對(duì)用戶名的檢測(cè)示例,需要的朋友可以參考下2014-03-03
ASP.NET生成兩個(gè)日期范圍內(nèi)隨機(jī)時(shí)間的實(shí)現(xiàn)方法
這篇文章主要介紹了ASP.NET生成兩個(gè)日期范圍內(nèi)隨機(jī)時(shí)間的實(shí)現(xiàn)方法,通過自定義函數(shù)記錄開始時(shí)間與結(jié)束時(shí)間確定時(shí)間范圍進(jìn)而生成該時(shí)間段的隨機(jī)時(shí)間,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
ASP.NET Core中使用令牌桶限流的實(shí)現(xiàn)
這篇文章主要介紹了ASP.NET Core中使用令牌桶限流的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Asp.Net Core 調(diào)用第三方Open API查詢物流數(shù)據(jù)的示例
這篇文章主要介紹了Asp.Net Core 調(diào)用第三方Open API查詢物流數(shù)據(jù)的示例,幫助大家更好的理解和學(xué)習(xí)使用Asp.Net Core,感興趣的朋友可以了解下2021-03-03

