文章出處

目錄

MVC5 網站開發實踐  概述

MVC5 網站開發實踐  1、建立項目

MVC5 網站開發實踐  2、后臺管理

 

1、 創建SHA256加密方法。

在Data項目中添加文件夾【Security】,在文件夾中添加類 【Encryption】,在類中寫一個SHA256加密方法。

using System;
using System.Security.Cryptography;
using System.Text;

namespace Ninesky.Data.Security
{
    /// <summary>
    /// 加密類
    /// <remarks>
    /// 創建:2014.12.13
    /// </remarks>
    /// </summary>
    public class Encryption
    {
        /// <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);
        }
    }
}

 

2、 Website項目添加對 Data項目的引用。

3、添加登錄視圖模型

在Config區域的Models文件夾添加視圖模型類【LoginViewModel】,代碼如下:

using System.ComponentModel.DataAnnotations;

namespace Ninesky.Website.Areas.Config.Models
{
    /// <summary>
    /// 登陸模型
    /// <remarks>
    /// 創建:2014.12.13
    /// </remarks>
    /// </summary>
    public class LoginViewModel
    {
        [StringLength(20, MinimumLength = 2, ErrorMessage = "{0}長度{2}-{1}個字符")]
        [Display(Name = "賬號")]
        public string Account { get; set; }

        [StringLength(20, MinimumLength = 4, ErrorMessage = "{0}長度{2}-{1}個字符")]
        [Display(Name = "密碼")]
        public string Password { get; set; }
    }
}

4、添加管理員控制器

在config的Controller文件夾上點右鍵創建控制器【MVC5控制器-空】,名稱輸入【AdministratorController】,在控制器

添加一個【Login】action,和一個HttpPost方式的【Login】action。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using Ninesky.User;
using Ninesky.Data.Security;

namespace Ninesky.Website.Areas.Config.Controllers
{
    /// <summary>
    /// 管理員控制器
    /// <remarks>
    /// 創建:2014.12.13
    /// </remarks>
    /// </summary>
    public class AdministratorController : Controller
    {
        private AdministratorService _adminService = new AdministratorService(ContextFactory.GetCurrentContext());
        // 登陸
        public ActionResult Login()
        {
            return View();
        }

        [ValidateAntiForgeryToken()]
        [HttpPost]
        public ActionResult Login(Models.LoginViewModel loginVM)
        {
            if (ModelState.IsValid)
            {
                var _admin = _adminService.Find(a => a.Account == loginVM.Account);
                if (_admin == null) ModelState.AddModelError("Account", "賬號不存在");
                else if (Encryption.Sha256(loginVM.Password) != _admin.Password) ModelState.AddModelError("Password", "密碼不正確");
                else 
                {
                    _admin.LoginTime = System.DateTime.Now;
                    _admin.LoginIp = Request.UserHostAddress;
                    _adminService.Update(_admin);
                    Session.Add("Account", loginVM.Account);
                    Session.Add("Password", _admin.Password);
                    return RedirectToAction("Index", "Home");
                }
            }
            return View(loginVM);
        }
    }
}

HttpPost方式的action中先驗證模型是否有錯誤,然后驗證用戶是否存在和密碼是否正確,通過后更新管理員登錄時間和ip,將賬號和密碼保存到session中,然后跳轉到Home/index頁面。

5、 添加視圖。

在”Login“action上點右鍵添加視圖。

image

修改代碼稍作修改,添加對bootstrap的引用,代碼如下:

image

6、啟用遷移。

在程序包管理控制臺輸入“Enable-Migrations”命令啟用遷移。

image

然后打開Website項目Migrations文件夾下的“Configuration.cs”,將構造函數中的“AutomaticMigrationsEnabled = false;”改為“AutomaticMigrationsEnabled = true;”

7、創建數據庫

再次在程序包管理控制臺輸入“Update-Database”命令來創建數據庫。然后在服務器資源管理器中查看剛創建

8、添加一個管理員賬號

數據庫的管理員表的數據。然后在表中添加一個管理員,賬號”admin”,密碼”jGl25bVBBBW96Qi9Te4V37Fnqchz/Eu4qB9vKrRIqRg=“ 如圖

image

9、測試登錄。

在瀏覽器中打開登錄視圖,賬號和密碼都輸入”admin“,測試一下可以正常調轉。

image

 

============================

代碼:http://pan.baidu.com/s/1mgtBbxI


文章列表




Avast logo

Avast 防毒軟體已檢查此封電子郵件的病毒。
www.avast.com


arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()