MVC4制作网站教程第二章 部分用户功能实现代码

用户部分要实现的功能有:
序 
一、用户 
1.1用户注册 
1.2用户登录
1.3修改密码 
1.4修改资料

要实现这些目的首先新建用户(Model)模型

/// <summary>
 /// 用户模型
 /// </summary>
 public class User
 {
 [Key]
 public int UserId { get; set; }
 /// <summary>
 /// 用户组Id
 /// </summary>
 [Display(Name="用户组Id")]
 [Required(ErrorMessage = "×")]
 public int GroupId { get; set; }
 /// <summary>
 /// 用户名
 /// </summary>
 [Display(Name="用户名",Description="4-20个字符。")]
 [Required(ErrorMessage = "×")]
 [StringLength(20, MinimumLength = 4, ErrorMessage = "×")]
 public string UserName { get; set; }
 /// <summary>
 /// 密码
 /// </summary>
 [Required]
 [StringLength(256)]
 public string Password { get; set; }
 /// <summary>
 /// 性别【0-男;1-女;2-保密】
 /// </summary>
 [Display(Name="性别")]
 [Required(ErrorMessage = "×")]
 [Range(0,2,ErrorMessage = "×")]
 public byte Gender { get; set; }
 /// <summary>
 /// Email
 /// </summary>
 [Display(Name="Email",Description="请输入您常用的Email。")]
 [Required(ErrorMessage = "×")]
 [EmailAddress(ErrorMessage = "×")]
 public string Email { get; set; }
 /// <summary>
 /// 密保问题
 /// </summary>
 [Display(Name="密保问题",Description="请正确填写,在您忘记密码时用户找回密码。4-20个字符。")]
 [Required(ErrorMessage = "×")]
 [StringLength(20, MinimumLength = 4, ErrorMessage = "×")]
 public string SecurityQuestion { get; set; }
 /// <summary>
 /// 密保答案
 /// </summary>
 [Display(Name="密保答案",Description="请认真填写,忘记密码后回答正确才能找回密码。2-20个字符。")]
 [Required(ErrorMessage = "×")]
 [StringLength(20, MinimumLength = 2, ErrorMessage = "×")]
 public string SecurityAnswer { get; set; }
 /// <summary>
 /// QQ号码
 /// </summary>
 [Display(Name="QQ号码")]
 [RegularExpression("^[1-9][0-9]{4-13]$",ErrorMessage = "×")]
 [StringLength(12, MinimumLength = 6, ErrorMessage = "×")]
 public string QQ { get; set; }
 /// <summary>
 /// 电话号码
 /// </summary>
 [Display(Name="电话号码",Description="常用的联系电话(手机或固话),固话格式为:区号-号码。")]
 [RegularExpression("^[0-9-]{11-13}$",ErrorMessage = "×")]
 public string Tel { get; set; }
 /// <summary>
 /// 联系地址
 /// </summary>
 [Display(Name="联系地址",Description="常用地址,最多80个字符。")]
 [StringLength(80, ErrorMessage = "×")]
 public string Address { get; set; }
 /// <summary>
 /// 邮编
 /// </summary>
 [Display(Name="邮编")]
 [RegularExpression("^[0-9]{6}$",ErrorMessage = "×")]
 public string PostCode { get; set; }
 /// <summary>
 /// 注册时间
 /// </summary>
 public DateTime? RegTime { get; set; }
 /// <summary>
 /// 上次登录时间
 /// </summary>
 public DateTime? LastLoginTime { get; set; }

 /// <summary>
 /// 用户组
 /// </summary>
 public virtual UserGroup Group { get; set; }
 }

下面添加用户Controller。在Controller文件夹点右键 选择新建控制器名称输入UserController,完成后生成代码如下:

using System.Web.Mvc;
using CMS.Models;

namespace CMS.Controllers
{
 public class UserController : Controller
 {

 public ActionResult Register()
 {
 return View();
 }

 //
 // POST: /User/Create

 [HttpPost]
 public ActionResult Register(UserRegister uerReg)
 {
 try
 {
 // TODO: Add insert logic here

 return RedirectToAction("Index");
 }
 catch
 {
 return View();
 }
 }
 }
}

马上涉及的问题就是数据的存取,本来准备用Repository模式做,后来觉得用Repository模式在一个人写个简单那网站的情况下意义不大,写起来反而有点啰嗦,干脆用伪Repository模式写。项目中新建Repository文件夹。在文件夹中新建类CMS,用来实现EF的Context。代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using CMS.Models;

namespace CMS.Repository
{
 public class CMSContext:DbContext
 {
 public DbSet<User> Users { get; set; }
 }
}

简单吧。再建一个类RepositoryBase,用来做***Repository的基类,里面写Add,Update,Delete,Find几个虚函数,方便在继承类里面这几个函数的名称统一。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace CMS.Repository
{
 public class RepositoryBase<TModel>
 {
 private CMSContext dbContext;
 public RepositoryBase()
 {
 dbContext = new CMSContext();
 }
 /// <summary>
 /// 添加【继承类重写后才能正常使用】
 /// </summary>
 public virtual bool Add(TModel Tmodel) { return false; }
 /// <summary>
 /// 更新【继承类重写后才能正常使用】
 /// </summary>
 public virtual bool Update(TModel Tmodel) { return false; }
 /// <summary>
 /// 删除【继承类重写后才能正常使用】
 /// </summary>
 public virtual bool Delete(int Id) { return false; }
 /// <summary>
 /// 查找指定值【继承类重写后才能正常使用】
 /// </summary>
 public virtual TModel Find(int Id) { return default(TModel); }
 ~RepositoryBase()
 {
 if (dbContext != null)
 {
 dbContext.Dispose();
 }
 }
 }
}

可以写UserRepository的具体实现了,新建UserRepository类。重写Add,Update方法后代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using CMS.Models;

namespace CMS.Repository
{
 public class UserRepository:RepositoryBase<User>
 {
 private CMSContext dbContext;
 public UserRepository()
 {
 dbContext = new CMSContext();
 }
 /// <summary>
 /// 添加用户
 /// </summary>
 /// <param name="user">用户信息</param>
 /// <returns></returns>
 public override bool Add(User user)
 {
 if (user == null) return false;
 dbContext.Users.Add(user);
 if (dbContext.SaveChanges() > 0) return true;
 else return false;
 }
 /// <summary>
 /// 更新用户信息
 /// </summary>
 /// <param name="user"></param>
 /// <returns></returns>
 public override bool Update(User user)
 {
 var _user = dbContext.Users.SingleOrDefault(u => u.UserId == user.UserId);
 if (_user == null) return false;
 _user = user;
 if (dbContext.SaveChanges() > 0) return true;
 else return false;
 }
 //public override
 }
}

到这里Repository的基本模式也出来了,现在MVC中的M和C都出来了就差V了,少了V相当于高富帅少了“富”在高,再帅都没用。那么马上下手为了写view做准备。 
@Html.Label可以用来显示字段的Display(Name=“”),@Html.DisplayText显示模型中字段值。没有找到用来显示模型中字段的Display(……,Description=“”)属性的HtmlHelper。先自己写一个用。在项目中新建Extensions文件夹,右键添加类DisplayDescriptionExtensions,在生成的代码中将命名空间改为System.Web.Mvc.Html,添加两个静态方法DisplayDescription和DisplayDescriptionFor。完成后代码 :

using System.Linq.Expressions;

namespace System.Web.Mvc.Html
{
 public static class DisplayDescriptionExtensions
 {
 /// <summary>
 /// 模型描述信息
 /// </summary>
 /// <param name="htmlHelper"></param>
 /// <param name="name"></param>
 /// <returns></returns>
 public static MvcHtmlString DisplayDescription(this HtmlHelper htmlHelper, string name)
 {
 ModelMetadata _modelMetadata = ModelMetadata.FromStringExpression(name, htmlHelper.ViewData);
 return MvcHtmlString.Create(_modelMetadata.Description);
 }
 /// <summary>
 /// 模型描述信息
 /// </summary>
 /// <typeparam name="TModel"></typeparam>
 /// <typeparam name="TResult"></typeparam>
 /// <param name="htmlHelper"></param>
 /// <param name="expression"></param>
 /// <returns></returns>
 public static MvcHtmlString DisplayDescriptionFor<TModel, TResult>(this HtmlHelper<TModel> htmlHelper, Expression<Func<TModel, TResult>> expression)
 {
 ModelMetadata _modelMetadata = ModelMetadata.FromLambdaExpression(expression,htmlHelper.ViewData);
 return MvcHtmlString.Create(_modelMetadata.Description);
 }
 }
}

好了,在视图中就可以直接用@Html.DisplayDescriptionFor(model => model.UserName)或@Html.DisplayDescription(“.UserName”)调用描述信息了.

到了这里后,大致的准备工作差不多了,还有两个小东东实现一下就可以写具体功能了。

第一个小东东:验证码。验证码分两块一是随机获取一定位数的字符,另一块是把字符绘制成图片。

在项目中添加Common 文件夹,在文件夹中新建Text类,在类实现函数VerificationText()利用Random获取指定长度的随机字符串,写完后的代码:

using System;

namespace CMS.Common
{
 /// <summary>
 /// 文本相关
 /// </summary>
 public class Text
 {
 /// <summary>
 /// 获取验证码【字符串】
 /// </summary>
 /// <param name="Length">验证码长度【必须大于0】</param>
 /// <returns></returns>
 public static string VerificationText(int Length)
 {
 char[] _verification = new Char[Length];
 Random _random = new Random();
 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' };
 for (int i = 0; i < Length; i++)
 {
 _verification[i] = _dictionary[_random.Next(_dictionary.Length - 1)];
 }
 return new string(_verification);
 }
 }
}

现在可以绘制验证码了,这里会用到.net的GDI+,我看了很多朋友写的验证码,一般都绘制了很多干扰点和干扰线,目的是为了使验证码不容易被电脑,个人觉得把绘制字的时候用材质刷绘制应该也能达到目的,所以找了一幅水彩画的材质。

用这个做字的材质也应该不太容易别识别吧,开始写绘图的代码,在UserController里新建名为VerificationCode的Action,代码如下:

/// <summary>
 /// 绘制验证码
 /// </summary>
 /// <returns></returns>
 public ActionResult VerificationCode()
 {
 int _verificationLength = 6;
 int _width = 100, _height = 20;
 SizeF _verificationTextSize;
 Bitmap _bitmap = new Bitmap(Server.MapPath("~/Skins/Common/Texture.jpg"),true);
 TextureBrush _brush = new TextureBrush(_bitmap);
 //获取验证码
 string _verificationText = Common.Text.VerificationText(_verificationLength);
 //存储验证码
 Session["VerificationCode"] = _verificationText.ToUpper();
 Font _font = new Font("Arial", 14, FontStyle.Bold);
 Bitmap _image = new Bitmap(_width, _height);
 Graphics _g = Graphics.FromImage(_image);
 //清空背景色
 _g.Clear(Color.White);
 //绘制验证码
 _verificationTextSize = _g.MeasureString(_verificationText, _font);
 _g.DrawString(_verificationText,_font,_brush,(_width-_verificationTextSize.Width)/2,(_height-_verificationTextSize.Height)/2);
 _image.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
 return null;
 }

打开浏览器看下效果还不错。到此准备工作完成。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • ASP.NET MVC5网站开发管理列表、回复及删除(十三)

    一.管理列表 跟上次我的列表相似,直接贴代码了. 首先打开Consultation控制器,添加ManageList方法 /// <summary> /// 咨询管理 /// </summary> /// <returns></returns> public ActionResult ManageList() { return View(); } 添加返回json数据的ManageJsonList public JsonResult ManageJsonLis

  • ASP.NET MVC5网站开发显示文章列表(九)

    老习惯,先上个效果图: 1.在IBLL 在InterfaceCommonModelService接口中添加获取公共模型列表的方法 首先排序方法 /// <summary> /// 排序 /// </summary> /// <param name="entitys">数据实体集</param> /// <param name="roderCode">排序代码[默认:ID降序]</param> /

  • ASP.NET MVC5网站开发之展示层架构(五)

    展示层由Ninesky.Web项目实现,负责网站内容的显示,项目包含Member和Control两个区域. Member区域实现网站内容的管理,Control区域实现网站系统管理.结构.功能图如下:  一.Member区域 1.添加Member区域 Ninesky.Web[右键]-> 添加->区域 . 在弹出的添加区域对话框输入区域名称:Member,完成区域添加. 2.添加Home控制器 Ninesky.Web->Areas->Member->Controllers[右键]

  • ASP.NET MVC5网站开发用户登录、注销(五)

    一.创建ClaimsIdentity ClaimsIdentity(委托基于声明的标识)是在ASP.NET Identity身份认证系统的登录时要用到,我们在UserService中来生成它. 1.打开IBLL项目InterfaceUserService接口,添加接口方法ClaimsIdentity CreateIdentity(User user, string authenticationType); 2.打开BLL项目的UserService类,添加CreateIdentity方法的实现代

  • ASP.NET MVC5 网站开发框架模型、数据存储、业务逻辑(三)

    前面项目的层次和调用关系都说明了,关系如下图 采用三层架构的时候,研究过BLL层的必要性,觉得业务逻辑完全可以在controller里实现,没有必要单独做一个项目,另一个分层多了会影响性能.后来我还是把业务逻辑独立出来,原因如下: 业务逻辑写进controller里代码看着比较混乱,时间久了代码容易理不清. 在controller里直接写逻辑重复代码会不较多,开发效率低. 分项目有利于代码重用,有时候可以直接拿到其他项目中稍作修改就可以用. 对于性能我觉得分层多了肯定会有影响,但是不会很大.现在

  • ASP.NET MVC5网站开发用户注册(四)

    一.默认Web项目的更改 用户这部分还是自己做,所以删除自动生成的用户相关代码. 二.添加Member区域 在web项目上点右键 添加 区域Member. 添加Home控制器,选择MVC5控制器-空 我们给public ActionResult Index()添加一个视图,代码很简单就是显示下用户名 @{ ViewBag.Title = "会员中心"; } <h2>欢迎你!@User.Identity.Name </h2> 我们先运行一下,出错啦. 这是因为项目

  • ASP.NET MVC5网站开发咨询管理的架构(十一)

    一.总体说明 1.实现功能 2.类图 由于文章部分把大部分类都是实现了,这里仅多了一个Consultation类. 二.创建咨询模型类 在Ninesky.Models项目添加类Consultation(咨询模型),该模型跟Article类似都是CommonModel的扩展. 1.添加Consultation类. using System; using System.ComponentModel.DataAnnotations; namespace Ninesky.Models { /// <su

  • ASP.NET MVC5网站开发文章管理架构(七)

    一.总体说明 先看一下文章管理设想要实现的功能: 再看一下类图 这里Category是栏目:CommonModel是公共模型:Article是文章:Attachment是附件: CommonModel是内容管理这块抽取出来的公共部分,像文章,咨询甚至产品都有一些共同的内容这里把它单独提取出来作为一个类.CommonModel可能包含一片文章,包含一组附件,包含一系列评论,他们之间的关系类图中已经表示出来.  二.搭建架构 这个顺序根以前一样 1.IDAL 在IDAL添加接口InterfaceCo

  • ASP.NET MVC5网站开发之总体概述(一)

    由于前几次都没能写完,这次年底总算有自由时间了,又想继续捣鼓一下.于是下载了VS 2015专业版(不知为什么我特别钟爱专业版,而不喜欢企业版).由于以前的教训,我这次决定写一个极简的Deom,简到什么程度呢?简单到只实现添加.修改栏目,用户登录后可以添加管理文章.管理员登陆后可以修改网站设置(也就标题.版权信息等)这些功能.为了避免以前大家经常搞不清哪个是最新的代码的情况,这次我准备把代码直接发布到Codeplex.com上做个代码开源,到时候大家直接去Codeplex.com下载最新代码就行了

  • ASP.NET MVC5网站开发之用户添加和浏览2(七)

    一.数据存储层 1.查找分页列表 在写用户列表时遇到了问题,考虑到用户可能会较多的情况需要分页,在数据存储层写的方法是public IQueryable<T> FindPageList<TKey>(int pageSize, int pageIndex, out int totalNumber, Expression<Func<T, bool>> where, Expression<Func<T, TKey>> order, bool

随机推荐