欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > ASP.NET MVC5網站開發用戶注冊(四)

ASP.NET MVC5網站開發用戶注冊(四)

熱門標簽:辦公用地圖標注網點怎么操作 聊城智能電銷機器人電話 安陸市地圖標注app 南昌自動外呼系統線路 寧德防封版電銷卡 云南外呼系統代理 上海市三維地圖標注 西寧電銷外呼系統公司 海東防封電銷卡

一、默認Web項目的更改
用戶這部分還是自己做,所以刪除自動生成的用戶相關代碼。

二、添加Member區域
在web項目上點右鍵 添加 區域Member。

添加Home控制器,選擇MVC5控制器-空

我們給public ActionResult Index()添加一個視圖,代碼很簡單就是顯示下用戶名

@{
 ViewBag.Title = "會員中心";
}

h2>歡迎你!@User.Identity.Name 
 /h2>

我們先運行一下,出錯啦。

這是因為項目中有兩個名為Home的控制器,必須在路由中加上命名空間。先打開區域中的MemberAreaRegistration添加命名空間。

再打開項目中的RouteConfig,添加命名空間

再刷新瀏覽器,可以正常顯示。

再添加用戶控制器UserController。

三、模型類的更改
在這里先對Models項目User模型進行修改,原來考慮的是每個用戶只能屬于一個用戶組,后來仔細考慮了一下,還是不太合適,比如一個用戶兼任多個角色,所以還是把用戶和用戶組改成一對多的關系。

  • User模型。在模型中刪除GroupID,刪除外鍵Group。
  • Role模型。原來UserGroup(用戶組)改為角色,考慮到權限管理感覺叫角色比叫戶組更加合適,另外角色的含義更廣,可以是指用戶組,也可以指職位,還可以指部門……修改后代碼如下: 
using System.ComponentModel.DataAnnotations;

namespace Ninesky.Models
{
 /// summary>
 /// 角色
 /// remarks>
 /// 創建:2014.02.02
 /// 修改:2014.02.16
 /// /remarks>
 /// /summary>
 public class Role
 {
 [Key]
 public int RoleID { get; set; }

 /// summary>
 /// 名稱
 /// /summary>
 [Required(ErrorMessage="必填")]
 [StringLength(20, MinimumLength = 2, ErrorMessage = "{1}到{0}個字")]
 [Display(Name="名稱")]
 public string Name { get; set; }

 /// summary>
 /// 角色類型br />
 /// 0普通(普通注冊用戶),1特權(像VIP之類的類型),3管理(管理權限的類型)
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [Display(Name = "用戶組類型")]
 public int Type { get; set; }

 /// summary>
 /// 說明
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [StringLength(50, ErrorMessage = "少于{0}個字")]
 [Display(Name = "說明")]
 public string Description { get; set; }

 /// summary>
 /// 獲取角色類型名稱
 /// /summary>
 /// returns>/returns>
 public string TypeToString()
 {
 switch (Type)
 {
 case 0:
  return "普通";
 case 1:
  return "特權";
 case 2:
  return "管理";
 default:
  return "未知";
 }
 }
 }
}

UserRoleRelation類。在Models項目添加角色關系類UserRoleRelation類,代碼:

using System.ComponentModel.DataAnnotations;

namespace Ninesky.Models
{
 /// summary>
 /// 用戶角色關系
 /// remarks>
 /// 創建:2014.02.16
 /// /remarks>
 /// /summary>
 public class UserRoleRelation
 {
 [Key]
 public int RelationID { get; set; }

 /// summary>
 /// 用戶ID
 /// /summary>
 [Required()]
 public int UserID { get; set; }
 
 /// summary>
 /// 角色ID
 /// /summary>
 [Required()]
 public int RoelID { get; set; }
 }
}

NineskyDbContext類。 如下圖藍色框為修改部分,紅框為新增加

三、驗證碼及Sha256加密
1、驗證碼
現在驗證碼是網站的必須功能,我把驗證碼功能分成三塊:創建驗證碼字符、根據驗證碼生成圖片、User控制器action中保存驗證碼并返回圖片。

創建驗證碼字符 CreateVerificationText()

在Common中添加Security類,在類中利用偽隨機數生成器生成驗證碼字符串。

/// summary>
 /// 創建驗證碼字符
 /// /summary>
 /// param name="length">字符長度/param>
 /// returns>驗證碼字符/returns>
 public static string CreateVerificationText(int length)
 {
 char[] _verification = new char[length];
 char[] _dictionary = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };
 Random _random = new Random();
 for (int i = 0; i  length; i++) { _verification[i] = _dictionary[_random.Next(_dictionary.Length - 1)]; }
 return new string(_verification);
 }

根據驗證碼生成圖片CreateVerificationImage()
思路是使用GDI+創建畫布,使用偽隨機數生成器生成漸變畫刷,然后創建漸變文字。

/// summary>
 /// 創建驗證碼圖片
 /// /summary>
 /// param name="verificationText">驗證碼字符串/param>
 /// param name="width">圖片寬度/param>
 /// param name="height">圖片長度/param>
 /// returns>圖片/returns>
 public static Bitmap CreateVerificationImage(string verificationText, int width, int height)
 {
 Pen _pen= new Pen(Color.Black);
 Font _font = new Font("Arial", 14, FontStyle.Bold);
 Brush _brush = null;
 Bitmap _bitmap = new Bitmap(width,height);
 Graphics _g = Graphics.FromImage(_bitmap);
 SizeF _totalSizeF = _g.MeasureString(verificationText,_font);
 SizeF _curCharSizeF;
 PointF _startPointF = new PointF((width-_totalSizeF.Width)/2,(height-_totalSizeF.Height)/2);
 //隨機數產生器
 Random _random =new Random();
 _g.Clear(Color.White);
 for(int i=0;iverificationText.Length;i++)
 {
 _brush = new LinearGradientBrush(new Point(0,0),new Point(1,1),Color.FromArgb(_random.Next(255),_random.Next(255),_random.Next(255)),Color.FromArgb(_random.Next(255),_random.Next(255),_random.Next(255)));
 _g.DrawString(verificationText[i].ToString(),_font,_brush,_startPointF);
 _curCharSizeF = _g.MeasureString(verificationText[i].ToString(),_font);
 _startPointF.X+= _curCharSizeF.Width;
 }
 _g.Dispose();
 return _bitmap;
 }

User控制器action中保存驗證碼并返回圖片
首先添加User控制器,在Member區域中添加控制器UserController。在控制器中寫一個VerificationCode方法。過程是:在方法中我們先創建6位驗證碼字符串->使用CreateVerificationImage創建驗證碼圖片->把圖片寫入OutputStream中->把驗證碼字符串寫入TempData中。

保存在TempData中和Session中的區別:TempData只傳遞一次,也就是傳遞到下一個action后,action代碼執行完畢就會銷毀,Session會持續保存,所以驗證碼用TempData比較合適。

/// summary>
 /// 驗證碼
 /// /summary>
 /// returns>/returns>
 public ActionResult VerificationCode()
 {
 string verificationCode = Security.CreateVerificationText(6);
 Bitmap _img = Security.CreateVerificationImage(verificationCode, 160, 30);
 _img.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
 TempData["VerificationCode"] = verificationCode.ToUpper();
 return null;
 }

我們看看生成圖驗證碼效果:

2、Sha256加密
在COmmon項目的Security類中添加靜態方法Sha256(string plainText)

/// summary>
 /// 256位散列加密
 /// /summary>
 /// param name="plainText">明文/param>
 /// returns>密文/returns>
 public static string Sha256(string plainText)
 {
 SHA256Managed _sha256 = new SHA256Managed();
 byte[] _cipherText = _sha256.ComputeHash(Encoding.Default.GetBytes(plainText));
 return Convert.ToBase64String(_cipherText);
 }

四、注冊
在Ninesky.Web.Areas.Member.Models中添加注冊視圖模型

using System.ComponentModel.DataAnnotations;

namespace Ninesky.Web.Areas.Member.Models
{
 public class RegisterViewModel
 {
 /// summary>
 /// 用戶名
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [StringLength(20, MinimumLength = 4, ErrorMessage = "{2}到{1}個字符")]
 [Display(Name = "用戶名")]
 public string UserName { get; set; }

 /// summary>
 /// 顯示名
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [StringLength(20, MinimumLength = 2, ErrorMessage = "{2}到{1}個字符")]
 [Display(Name = "顯示名")]
 public string DisplayName { get; set; }

 /// summary>
 /// 密碼
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [Display(Name = "密碼")]
 [StringLength(20,MinimumLength=6,ErrorMessage="{2}到{1}個字符")]
 [DataType(DataType.Password)]
 public string Password { get; set; }

 /// summary>
 /// 確認密碼
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [Compare("Password", ErrorMessage = "兩次輸入的密碼不一致")]
 [Display(Name = "確認密碼")]
 [DataType(DataType.Password)]
 public string ConfirmPassword { get; set; }

 /// summary>
 /// 郵箱
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [Display(Name = "郵箱")]
 [DataType(DataType.EmailAddress,ErrorMessage="Email格式不正確")]
 public string Email { get; set; }

 /// summary>
 /// 驗證碼
 /// /summary>
 [Required(ErrorMessage = "必填")]
 [StringLength(6, MinimumLength = 6, ErrorMessage = "驗證碼不正確")]
 [Display(Name = "驗證碼")]
 public string VerificationCode { get; set; }
 }
}

在UserController中添加Register() action ,并返回直接返回強類型(RegisterViewModel)視圖

/// summary>
 /// 注冊
 /// /summary>
 /// returns>/returns>
 public ActionResult Register()
 {
 return View();
 }

視圖

@model Ninesky.Web.Areas.Member.Models.RegisterViewModel

@{
 ViewBag.Title = "注冊";
 Layout = "~/Views/Shared/_Layout.cshtml";
}


@using (Html.BeginForm()) 
{
 @Html.AntiForgeryToken()
 
 div class="form-horizontal">
 h4>用戶注冊/h4>
 hr />
 @Html.ValidationSummary(true)

 div class="form-group">
 @Html.LabelFor(model => model.UserName, new { @class = "control-label col-md-2" })
 div class="col-md-10">
 @Html.EditorFor(model => model.UserName)
 @Html.ValidationMessageFor(model => model.UserName)
 /div>
 /div>

 div class="form-group">
 @Html.LabelFor(model => model.DisplayName, new { @class = "control-label col-md-2" })
 div class="col-md-10">
 @Html.EditorFor(model => model.DisplayName)
 @Html.ValidationMessageFor(model => model.DisplayName)
 /div>
 /div>

 div class="form-group">
 @Html.LabelFor(model => model.Password, new { @class = "control-label col-md-2" })
 div class="col-md-10">
 @Html.EditorFor(model => model.Password)
 @Html.ValidationMessageFor(model => model.Password)
 /div>
 /div>

 div class="form-group">
 @Html.LabelFor(model => model.ConfirmPassword, new { @class = "control-label col-md-2" })
 div class="col-md-10">
 @Html.EditorFor(model => model.ConfirmPassword)
 @Html.ValidationMessageFor(model => model.ConfirmPassword)
 /div>
 /div>

 div class="form-group">
 @Html.LabelFor(model => model.Email, new { @class = "control-label col-md-2" })
 div class="col-md-10">
 @Html.EditorFor(model => model.Email)
 @Html.ValidationMessageFor(model => model.Email)
 /div>
 /div>

 div class="form-group">
 @Html.LabelFor(model => model.VerificationCode, new { @class = "control-label col-md-2" })
 div class="col-md-10">
 @Html.EditorFor(model => model.VerificationCode)
 img id="verificationcode" title="點擊刷新" src="@Url.Action("VerificationCode")" style="cursor:pointer" />
 @Html.ValidationMessageFor(model => model.VerificationCode)
 /div>
 /div>
 div class="checkbox">
 input type="checkbox" checked="checked" required />我同意 a href="#">《用戶注冊協議》/a> 
 /div>
 div class="form-group">
 div class="col-md-offset-2 col-md-10">
 input type="submit" value="注冊" class="btn btn-default" />
 /div>
 /div>
 /div>
}
script type="text/javascript">
 $("#verificationcode").click(function () {
 $("#verificationcode").attr("src", "@Url.Action("VerificationCode")?" + new Date());
 })
/script>

@section Scripts {
 @Scripts.Render("~/bundles/jqueryval")
}

再在用戶控制器中添加public ActionResult Register(RegisterViewModel register)用來處理用戶提交的注冊數據

[HttpPost]
 [ValidateAntiForgeryToken]
 public ActionResult Register(RegisterViewModel register)
 {
 if (TempData["VerificationCode"] == null || TempData["VerificationCode"].ToString() != register.VerificationCode.ToUpper())
 {
 ModelState.AddModelError("VerificationCode", "驗證碼不正確");
 return View(register);
 }
 if(ModelState.IsValid)
 {

 if (userService.Exist(register.UserName)) ModelState.AddModelError("UserName", "用戶名已存在");
 else
 {
  User _user = new User()
  {
  UserName = register.UserName,
  //默認用戶組代碼寫這里
  DisplayName = register.DisplayName,
  Password = Security.Sha256(register.Password),
  //郵箱驗證與郵箱唯一性問題
  Email = register.Email,
  //用戶狀態問題
  Status = 0,
  RegistrationTime = System.DateTime.Now
  };
  _user = userService.Add(_user);
  if (_user.UserID > 0)
  {
  return Content("注冊成功!");
  //AuthenticationManager.SignIn();
  }
  else { ModelState.AddModelError("", "注冊失敗!"); }
 }
 }
 return View(register);
 }

代碼中很多根用戶設置相關的內容先不考慮,等做到用戶設置時在會后來修改。注冊失敗時返回視圖并顯示錯誤;成功時返回視圖注冊成功,等下次做用戶登錄時可以讓用戶注冊完畢直接進行登錄。看看效果。

點擊注冊,注冊成功。

一個簡單的用戶注冊完成了,主要有驗證碼、sha256加密、注冊視圖模型、驗證用戶提交數據并保存等步驟。后面就是用戶注冊,注冊會用到ClaimsIdentity和HttpContext.GetOwinContext().Authentication.SignIn();

本文已被整理到了《ASP.NET MVC網站開發教程》,歡迎大家學習閱讀,更多內容還可以參考ASP.NET MVC5網站開發專題學習。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • ASP.NET MVC5網站開發用戶登錄、注銷(五)
  • PHP MVC模式在網站架構中的實現分析
  • ASP.NET MVC5 網站開發框架模型、數據存儲、業務邏輯(三)
  • MVC4 網站發布(整理+部分問題收集和解決方案)
  • CodeIgniter php mvc框架 中國網站
  • PHP發明人談MVC和網站設計架構 貌似他不支持php用mvc
  • ASP.NET MVC5網站開發項目框架(二)
  • ASP.NET MVC5網站開發顯示文章列表(九)
  • ASP.NET MVC5網站開發添加文章(八)
  • 一步步打造簡單的MVC電商網站BooksStore(1)

標簽:南寧 汕尾 青海 衢州 崇左 贛州 洛陽 平涼

巨人網絡通訊聲明:本文標題《ASP.NET MVC5網站開發用戶注冊(四)》,本文關鍵詞  ASP.NET,MVC5,網站開發,用戶注冊,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP.NET MVC5網站開發用戶注冊(四)》相關的同類信息!
  • 本頁收集關于ASP.NET MVC5網站開發用戶注冊(四)的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    欧美熟妇精品一区二区蜜桃视频| 日韩精品中文字幕一区| 国产精品久久看| 国产成人综合亚洲网站| 中文字幕第24页| 久久影音资源网| 经典一区二区三区| 日韩不卡av在线| 国产欧美一区二区三区网站| 国产自产高清不卡| 2014亚洲天堂| 中文字幕在线不卡视频| av电影在线观看完整版一区二区| 翔田千里88av中文字幕| 国产精品久久久久久福利一牛影视| 国产盗摄精品一区二区三区在线| 91视频最新网址| 中文字幕日韩一区| 91农村精品一区二区在线| 欧洲人成人精品| 亚洲成在线观看| 一区二区不卡免费视频| 精品日韩欧美在线| 国产精品资源在线看| 国产探花在线视频| 亚洲精品日韩综合观看成人91| 一区二区在线免费观看视频| 8x福利精品第一导航| 免费在线观看成人| 一级二级黄色片| 亚洲欧洲成人av每日更新| 91视频一区二区三区| 在线播放欧美女士性生活| 蜜桃一区二区三区在线| 国产3级在线观看| 亚洲男人天堂av| 国产chinese中国hdxxxx| 日韩精品一区二| 国产激情91久久精品导航| 在线亚洲欧美专区二区| 天天影视涩香欲综合网 | 国产精品一区二区三区四区| 久久久久久久久久97| 亚洲素人一区二区| 男女性杂交内射妇女bbwxz| 精品奇米国产一区二区三区| 国产成人在线免费| 欧美日韩一区精品| 久久国内精品视频| 久草网站在线观看| 视频在线观看91| 国产传媒免费在线观看| 一二三四社区欧美黄| 乐播av一区二区三区| 中文字幕中文字幕中文字幕亚洲无线| 欧美图片自拍偷拍| 久久久久成人黄色影片| 91丝袜美腿高跟国产极品老师| 欧美一区2区视频在线观看| 国产精品正在播放| 欧美日韩一区视频| 国产一区高清在线| 欧美日韩一区二区不卡| 国产一区二区三区在线观看免费视频| 色综合网站在线| 久久精品国产亚洲高清剧情介绍| 欧美色图亚洲视频| 喷水一区二区三区| 在线欧美日韩精品| 精品午夜久久福利影院| 欧美日韩高清影院| 国产中文字幕精品| 91精品在线免费| 成人高清视频免费观看| 日韩精品一区二区三区四区| 91蜜桃网址入口| 国产日韩精品一区| 91玉足脚交白嫩脚丫| 亚洲欧美区自拍先锋| 极品人妻videosss人妻| 亚洲午夜私人影院| 91麻豆精品成人一区二区| 欧美bbbbb| 欧美性生活一区| 国产成人99久久亚洲综合精品| 91精品国产欧美一区二区成人 | 国产精品资源在线看| 91精品综合久久久久久| 91视频一区二区三区| 欧美激情艳妇裸体舞| wwwwww日本| 亚洲国产日韩精品| 一本大道久久a久久综合婷婷| 精品亚洲porn| 日韩欧美成人激情| 欧美一级片在线免费观看| 中文字幕日韩欧美一区二区三区| 超碰人人干人人| 蜜臀久久99精品久久久久宅男| 欧美日韩黄色影视| 91免费观看视频在线| 国产精品美女久久久久久久久| 人人妻人人澡人人爽| 免费看黄色91| 欧美一区二区三区系列电影| 波多野结衣办公室双飞 | 亚洲图片你懂的| 国产黄色片在线| 久久国产精品99精品国产| 91精品国产欧美一区二区18| 中文字幕视频观看| 一级精品视频在线观看宜春院| 色综合久久中文综合久久97| 国产成人av一区二区三区在线| 久久久精品蜜桃| 精品熟妇无码av免费久久| 麻豆成人免费电影| 日韩美女在线视频| 黄色国产在线观看| 日韩av午夜在线观看| 9191久久久久久久久久久| 美女伦理水蜜桃4| 黄色香蕉视频在线观看| 国产一区二区影院| 国产日韩一级二级三级| 手机av在线不卡| 国产老妇另类xxxxx| 国产日本亚洲高清| 日本美女黄色一级片| 东方欧美亚洲色图在线| 中文字幕亚洲欧美在线不卡| 色婷婷国产精品综合在线观看| www.欧美日韩| 亚洲女女做受ⅹxx高潮| 欧美日韩中字一区| 无码av免费精品一区二区三区| 视频在线观看一区二区三区| 日韩精品一区二区三区老鸭窝| 欧洲女同同性吃奶| 国产一区二区成人久久免费影院| 久久理论电影网| 91麻豆精品成人一区二区| 99视频精品全部免费在线| 亚洲欧美激情一区二区| 欧美三级视频在线观看| 88av在线播放| 久久99蜜桃精品| 国产欧美精品一区| 久久精品一区二区三区四区五区| 大白屁股一区二区视频| 一区二区三区在线不卡| 91精品欧美一区二区三区综合在| 狠狠人妻久久久久久综合蜜桃| 九九视频精品免费| 中文字幕在线一区二区三区| 欧美午夜电影在线播放| 日本黄色录像片| 韩国欧美国产一区| 亚洲欧洲性图库| 7777精品伊人久久久大香线蕉的 | 综合色中文字幕| 欧美久久久影院| 国产又大又粗又爽的毛片| 国产成人av电影| 亚洲国产毛片aaaaa无费看| 欧美va日韩va| 色欲人妻综合网| 日本久久久久久久久久| 精彩视频一区二区三区| 中文字幕综合网| 日韩一区二区视频在线观看| 亚洲图片第一页| 91免费在线播放| 麻豆国产91在线播放| 日韩理论片一区二区| 日韩一级完整毛片| 久久久久久久久久97| 国产精品久久久久久亚洲av| 极品少妇一区二区| 亚洲老妇xxxxxx| 精品久久久久久亚洲综合网| 侵犯稚嫩小箩莉h文系列小说| 稀缺呦国内精品呦| 国产高清不卡一区| 亚洲va欧美va国产va天堂影院| 国产日本亚洲高清| 91精品麻豆日日躁夜夜躁| 男人晚上看的视频| 亚洲一区二区乱码| 不卡的看片网站| 蜜臀精品久久久久久蜜臀| 亚洲免费看黄网站| 欧美精品一区二区三区很污很色的| 国产精品一区免费视频| 一区二区三区国产豹纹内裤在线| 2023国产精品| 欧美精品久久99久久在免费线 | 日韩视频在线观看免费视频| 亚洲欧洲国产视频| 成人97人人超碰人人99|