随便写写记录一下学习的过程

登陆

Models中添加添加

public class LoginViewModel
{
[Required(ErrorMessage = "*")]
[Display(Name = "机构号")]
public string UserName { get; set; } [Required(ErrorMessage = "*")]
[DataType(DataType.Password)]
[Display(Name = "密码")]
public string PassWord { get; set; } [Required(ErrorMessage = "*")]
[Display(Name = "验证码")]
public string Codeimg { get; set; } public string ErrorMsg { get; set; }
}

  Views代码:

其中ErrorMsg我是为了显示错误信息的,其他好的方法还不知道。。。

 @using (Html.BeginForm("Login", "Admin", new { ReturnUrl = ViewBag.ReturnUrl }, FormMethod.Post, new { @class = "form-horizontal", role = "form" }))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<div class="login_mid_right">
<div class="login_mid_right_ul">
<div class="form-group">
@Html.LabelFor(m => m.UserName, new { @class = "col-md-3 control-label" })
<div class="col-md-8">
@Html.TextBoxFor(m => m.UserName, new { @class = "form-control" })
</div>@Html.ValidationMessageFor(m => m.UserName)
</div>
<div class="form-group">
@Html.LabelFor(m => m.PassWord, new { @class = "col-md-3 control-label" })
<div class="col-md-8">
@Html.PasswordFor(m => m.PassWord, new { @class = "form-control" })
</div> @Html.ValidationMessageFor(m => m.PassWord)
</div>
<div class="form-group">
@Html.LabelFor(m => m.Codeimg, new { @class = "col-md-3 control-label" })
<div class="col-md-4">
@Html.TextBoxFor(m => m.Codeimg, new { @class = "form-control" }) </div> @Html.ValidationMessageFor(m => m.Codeimg)
&nbsp;&nbsp;
<img class="codeimg" title="看不清,点击刷新" alt="看不清,点击刷新" src="/Extensions/Codeimg.ashx" onclick="javascript:this.src=this.src+'?rnd=' + Math.random();" />
</div>
<div class="form-group">
<div class="col-md-offset-3 col-md-9">
<input type="submit" value="登 录" class="btn-lg btn-default" />
</div>
</div>
<div class="form-group">
<div class="col-md-offset-3 col-md-9">
@Html.ValidationMessageFor(m => m.ErrorMsg)
</div>
</div>
</div>
</div>
}

  登陆的验证,在对应的Controllers中:

public class AdminController : Controller
{
private SimonDBContext db = new SimonDBContext();
//
// GET: /Admin/
public ActionResult Index()
{
return View();
} public ActionResult Login()
{
return View();
} public ActionResult LoginOut()
{
Session.Clear();
Session.Abandon();
return RedirectToAction("Login", "Admin");
} [HttpPost]
public ActionResult Login([Bind(Include = "UserName,PassWord,Codeimg")] LoginViewModel login, string returnUrl)
{
//return View();
if (ModelState.IsValid)
{
int i = ;
if (Session["checkCode"].ToString() != login.Codeimg.ToUpper())
{
ModelState.AddModelError("ErrorMsg", "验证码不正确!");
}
else
{
i = Authentication(login.UserName, Common.Helper.Encryption.SHA256(login.PassWord));
}
if (i == )
{
//Cookie
//HttpCookie cookie = new HttpCookie("User");
//cookie.Values.Add("UserName", login.UserName);
//Response.Cookies.Add(cookie);
//Session
Session["userName"] = login.UserName;
return RedirectToAction("Index", "Admin");
}
else if (i == )
{
ModelState.AddModelError("ErrorMsg", "该用户已被禁用!");
}
else
{
ModelState.AddModelError("ErrorMsg", "密码或用户名错误!");
}
}
return View("Login");
}
/// <summary>
/// 登陆验证
/// </summary>
/// <param name="userName"></param>
/// <param name="pass"></param>
/// <returns>
/// 0:登录成功
/// 1:该用户已被禁用
/// 9:密码或用户名错误
/// </returns>
public int Authentication(string userName, string pass)
{
int res = ;
AdminManager am = db.AdminManager.SingleOrDefault(c => c.UserName == userName);
if (am == null)
{
return ;
}
if (am.Flag != "")
{
return ;
}
if (am.PassWord != pass)
{
return ;
}
return res;
}
}

做好了登陆,在其他页面就需要添加验证是否登陆,添加UserAuthorizeAttribute

public class UserAuthorizeAttribute : AuthorizeAttribute
{
protected override bool AuthorizeCore(HttpContextBase httpContext)
{
if (httpContext == null)
{
throw new ArgumentNullException("httpContext");
}
if (HttpContext.Current.Session["userName"] == null)
{ return false;
}
return true;
}
}

在需要验证的Controller上添加 [UserAuthorize]

MVC5----用户登陆及验证码的更多相关文章

  1. 模拟Post登陆带验证码的网站

    前言: 作者在一个项目需求 模拟用户登陆,获取该用户的订单记录. 该系统需要用户名,密码,验证码 (验证码为正楷的数字4位),于是参考网络一些文章,并进行了很多测试,总结步骤如下: 步骤1 : 通过h ...

  2. PHPCMS \phpcms\modules\member\index.php 用户登陆SQL注入漏洞分析

    catalog . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述2. 漏洞触发条件 0x1: POC http://localhost/p ...

  3. 一般处理程序生成简单的图片验证码并通过html验证用户输入的验证码是否正确

    一般处理程序生成简单的图片验证码并通过html验证用户输入的验证码是否正确       最近没事研究了下验证码的的动态生成及通过cookie实现HTML页面对用户输入的验证码的校验,简要如下: 1.写 ...

  4. 用户登陆,退出等基本Action

    用户登陆页面user_login.jsp对应action为login.do: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transiti ...

  5. .NET Core实战项目之CMS 第十六章 用户登录及验证码功能实现

    前面为了方便我们只是简单实现了基本业务功能的增删改查,但是登录功能还没有实现,而登录又是系统所必须的,得益于 ASP.NET Core的可扩展性因此我们很容易实现我们的登录功能.今天我将带着大家一起来 ...

  6. MVC基本登陆与验证码功能实现

    一.基本登陆实现与验证码功能实现,该功能是和spring.net功能集合使用的,因为后面要用到验证是否处于登陆状态 1. 先构建一个登陆页面 @{ Layout = null; } <!DOCT ...

  7. IOS开发之记录用户登陆状态

    上一篇博客中提到了用CoreData来进行数据的持久化,CoreData的配置和使用步骤还是挺复杂的.但熟悉CoreData的使用流程后,CoreData还是蛮好用的.今天要说的是如何记录我们用户的登 ...

  8. 使用Struts框架,实现用户登陆功能

    前言:本篇文章是本人这周学习的一个小结,在自我总结的同时,希望也能够给其他同学带来一点帮助.本文主要知识是参照书本上的知识点以及网上其他博客文章,在上机操练后的所得,具体源码主要来自http://bl ...

  9. Linux常用命令学习4---(挂载命令mount umount、用户登陆查看和用户交互命令 w who last lastlog)

    紧接着上一篇Linux的命令行的学习:Linux学习3---(文件的压缩和解压缩命令zip unzip tar.关机和重启命令shutdown reboot……) 1.挂载命令     简介      ...

  10. [PHP] - Laravel - 用户登陆中间件

    前言 Laravel 4中,可以使用Route::filter,而在Laravel 5中,没有了filter.php文件,官方建议使用中间件做. 下面是用户登陆的测试例子,涉及到的一些方法和使用,先参 ...

随机推荐

  1. SQL 表锁(转)

    其实你可以使用事务处理   比方说在一个字段里面添加一个boolean 的字段当你要处理该字段的时候就 True 哪么别的人都不可以进行操作 如果是False 哪么就可以进行操作--呵可--我是这样的 ...

  2. Java基础-新建项目、包和类

    1,新建项目

  3. SPOJ LIS2 Another Longest Increasing Subsequence Problem 三维偏序最长链 CDQ分治

    Another Longest Increasing Subsequence Problem Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://a ...

  4. iOS 2D绘图详解(Quartz 2D)之Transform(CTM,Translate,Rotate,Scale)

    前言:Quartz默认采用设备无关的user space来进行绘图,当context(画板)建立之后,默认的坐标系原点以及方向也就确认了,可以通过CTM(current transformation ...

  5. JavaEE系列之(一)JSP基础知识详解

    一.JSP基础语法     1.JSP简介        JSP(Java Server Pages),其根本是一个简化的Servlet设计,它实现了在Java中使用HTML标签.JSP是一种动态网页 ...

  6. python工具程序一、复制目录中指定扩展名的文件

    #!/usr/bin/env python # coding:utf-8 # xcopy Lib directory and rename all files to *d.lib import os ...

  7. 详解ARM的AMBA设备中的 DMA设备PL08X的Linux驱动

    1. 此文目的记录笔者对ARM的PL08x的DMA驱动PL08x.c理解.给其他不熟悉此DMA驱动的读者一点借鉴和参考.2. 适合读者你已经具备一定驱动编程能力,知道一些最基本的概念,比如用于输出输出 ...

  8. [转] 详解http和https的作用与区别

    PS: https就是http和TCP之间有一层SSL层,这一层的实际作用是防止钓鱼和加密.防止钓鱼通过网站的证书,网站必须有CA证书,证书类似于一个解密的签名.另外是加密,加密需要一个密钥交换算法, ...

  9. 使用dispatch_group实现并封装分组并发网络请求

    在实际开发中我们通常会遇到这样一种需求:某个页面加载时通过网络请求获得相应的数据,再做某些操作.有时候加载的内容需要通过好几个请求的数据组合而成,比如有两个请求A和B,我们通常为了省事,会将B请求放在 ...

  10. HTML+CSS实例——漂亮的查询部件(一)

    一.参考网址:www.kuhnsjewelers.com 二.效果: 三.HTML <div id="search-box"> <asp:TextBox ID=& ...