写在前面

今天回来的比较早,就趁着有空,把登录的代码更新一下。上篇文章实现了ajax的注册,这篇将实现登录,实现目标,ajax登录方式,如果勾选记住我,则下次不再输入用户名密码,直接跳转到网盘界面。

系列文章

[EF]vs15+ef6+mysql code first方式

[实战]MVC5+EF6+MySql企业网盘实战(1)

[实战]MVC5+EF6+MySql企业网盘实战(2)——用户注册

[实战]MVC5+EF6+MySql企业网盘实战(3)——验证码

[实战]MVC5+EF6+MySql企业网盘实战(4)——上传头像

[Bootstrap]modal弹出框

[实战]MVC5+EF6+MySql企业网盘实战(5)——登录界面,头像等比例压缩

[实战]MVC5+EF6+MySql企业网盘实战(5)——页面模板

[实战]MVC5+EF6+MySql企业网盘实战(5)——ajax方式注册

[实战]MVC5+EF6+MySql企业网盘实战(6)——ajax方式登录

代码

@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="企业,网盘,企业网盘">
<meta name="author" content="Muhammad Usman">
<title>登录</title>
<script src="~/Scripts/jquery-1.10.2.min.js"></script>
<link href="~/Content/Css/bootstrap-cerulean.min.css" rel="stylesheet" />
<link href="~/Content/Css/charisma-app.css" rel="stylesheet" />
<link href="~/Content/Css/jquery.noty.css" rel="stylesheet" /> <link href="~/Content/Css/elfinder.min.css" rel="stylesheet" />
<link href="~/Content/Css/elfinder.theme.css" rel="stylesheet" /> <link href="~/Content/Css/jquery.iphone.toggle.css" rel="stylesheet" />
<link href="~/Content/Css/animate.min.css" rel="stylesheet" />
<script>
$(function () {
//多选框
$("#chkRemember").click(function () {
if (!$(this).attr("checked")) {
$(this).attr("checked", 'checked');
} else {
$(this).removeAttr("checked");
};
});
//为登录按钮注册单击事件
$('#btnLogin').click(function () { $.ajax({
type: "post",
url: "/UserInfo/Login",
data: { userName: $("#txtUserName").val(), pwd: $("#txtPwd").val(), remember: $("#chkRemember").attr('checked') },
dataType: "json",
success: function (data) {
console.log(data);
data = JSON.parse(data);
if (data.code == 200) { } else {
$("#loginMsg").html("<span style='color:red;'>"+data.msg+"</span>");
}; }, error: function (msg) {
alert(data);
}
});
});
});
</script>
</head>
<body>
<div class="row"> <div class="row">
<div class="col-md-12 center login-header">
<h2>欢迎使用 Wolfy企业网盘</h2>
</div>
<!--/span-->
</div><!--/row-->
<div class="container">
<div class="row">
<div class="well col-md-5 center login-box">
<div class="alert alert-info" id="loginMsg">
请使用用户名和密码登录
</div> <fieldset>
<div class="input-group input-group-lg">
<span class="input-group-addon"><i class="glyphicon glyphicon-user red"></i></span>
<input type="text" class="form-control" id="txtUserName" placeholder="用户名">
</div>
<div class="clearfix"></div><br> <div class="input-group input-group-lg">
<span class="input-group-addon"><i class="glyphicon glyphicon-lock red"></i></span>
<input type="password" class="form-control" id="txtPwd" placeholder="密码">
</div>
<div class="clearfix"></div> <div class="input-prepend">
<label class="remember" for="chkRemember"><input type="checkbox" name="chkRemember" id="chkRemember" value="1" /> 记住我</label>
</div>
<div class="clearfix"></div> <p class="center col-md-5">
<button type="button" class="btn btn-primary" id="btnLogin">登录</button>
</p><a href="/UserInfo/Register" class="right" style="float:right;">注册</a>
</fieldset> </div>
<!--/span-->
</div><!--/row-->
</div><!--/fluid-row-->
</div>
</body>
</html>

Login.cshtml

目前还是使用session来保持状态,使用在action上加特性的方式,留待以后优化。

        [HttpGet]
public ActionResult Login()
{
UserInfo userInfo = null;
if (Request.Cookies["n"] != null && Request.Cookies["p"] != null)
{
string userName = Request.Cookies["n"].Value;
string pwd = Request.Cookies["p"].Value;
userInfo = _userInfoServiceRepository.Find(x => x.UserName == userName && x.Pwd == pwd);
if (userInfo!=null)
{
if (Session["user"] == null)
{
Session["user"] = userInfo;
}
//更新最后一次登录时间
userInfo.LoginDt = DateTime.Now;
_userInfoServiceRepository.Update(userInfo);
_userInfoServiceRepository.SaveChanges();
} }
return View();
}
/// <summary>
/// 登录
/// </summary>
/// <param name="userName"></param>
/// <param name="code"></param>
/// <returns></returns>
[HttpPost]
public JsonResult Login(string userName, string pwd, string remember)
{
if (!_userInfoServiceRepository.Exist(userName))
{
return new JsonResult() { Data = "{\"code\":500,\"msg\":\"用户名不存在\"}" };
}
if (!string.IsNullOrEmpty(pwd))
{
pwd = MD5Helper.GetMD5FromString(pwd);
}
else
{
return new JsonResult() { Data = "{\"code\":500,\"msg\":\"密码不能为空\"}" };
}
UserInfo userInfo = _userInfoServiceRepository.Find(x => x.UserName == userName && x.Pwd == pwd);
if (userInfo == null)
{
return new JsonResult() { Data = "{\"code\":500,\"msg\":\"用户名和密码不匹配\"}" };
}
if (!string.IsNullOrEmpty(remember) && remember.Equals("checked"))
{
HttpCookie nameCookie = new HttpCookie("n", userName);
nameCookie.Expires = DateTime.Now.AddDays();
//将md5串写入cookie,或者再次进行AES加密写入
HttpCookie pwdCookie = new HttpCookie("p", pwd);
pwdCookie.Expires = DateTime.Now.AddDays();
Response.Cookies.Add(nameCookie);
Response.Cookies.Add(pwdCookie);
}
//登录成功写入session
Session["user"] = userInfo;
//更新登录状态
userInfo.LoginDt = DateTime.Now;
_userInfoServiceRepository.Update(userInfo);
_userInfoServiceRepository.SaveChanges();
return new JsonResult() { Data = "{\"code\":200,\"msg\":\"登录成功\"}" };
}

测试

登录成功后,跳转到FileList页面。

总结

关于ajax方式登录的内容就到这里。下面将进入网盘的主页。

[实战]MVC5+EF6+MySql企业网盘实战(6)——ajax方式登录的更多相关文章

  1. [实战]MVC5+EF6+MySql企业网盘实战(28)——其他列表

    写在前面 本篇文章将实现,其他文件类型的列表. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘实战(1) [实战]MVC5+EF ...

  2. [实战]MVC5+EF6+MySql企业网盘实战(27)——应用列表

    写在前面 本篇文章将实现应用列表,同样和其他列表的不同之处,在于查询条件的不同. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘 ...

  3. [实战]MVC5+EF6+MySql企业网盘实战(4)——上传头像

    写在前面 最近又开始忙了,工期紧比较赶,另外明天又要去驾校,只能一个功能一个功能的添加了,也许每次完成的功能确实不算什么,等将功能都实现了,然后在找一个好点的ui对前端重构一下. 系列文章 [EF]v ...

  4. [实战]MVC5+EF6+MySql企业网盘实战(2)——验证码

    写在前面 断断续续,今天算是把验证码的东东弄出来了. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘实战(1) [实战]MVC5 ...

  5. [实战]MVC5+EF6+MySql企业网盘实战(2)——用户注册

    写在前面 上篇文章简单介绍了项目的结构,这篇文章将实现用户的注册.当然关于漂亮的ui,这在追后再去添加了,先将功能实现.也许代码中有不合适的地方,也只有在之后慢慢去优化了. 系列文章 [EF]vs15 ...

  6. [实战]MVC5+EF6+MySql企业网盘实战(1)

    写在前面 不久前,一个朋友让帮他弄一个单位的企业网盘的管理站点,一直忙,最近抽出了点时间,也想琢磨琢磨mvc,ef,mysql,这算是边琢磨,边实践吧. 系列文章 [实战]MVC5+EF6+MySql ...

  7. [实战]MVC5+EF6+MySql企业网盘实战(26)——音乐列表

    写在前面 本篇文章将实现,音乐列表,同样和其他列表的不同之处,在于查询条件的不同. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网 ...

  8. [实战]MVC5+EF6+MySql企业网盘实战(25)——种子列表

    写在前面 上篇文章实现了视频列表,本篇文章继续实现其他的文件列表.功能相似.这里就不再赘述. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MyS ...

  9. [实战]MVC5+EF6+MySql企业网盘实战(24)——视频列表

    写在前面 上篇文章实现了文档列表,所以实现视频列表就依葫芦画瓢就行了. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘实战(1) ...

  10. [实战]MVC5+EF6+MySql企业网盘实战(23)——文档列表

    写在前面 上篇文章实现了图片列表,这篇文章实现文档列表将轻车熟路,因为逻辑基本相似,只是查询条件的不同.这里将txt,doc,docx,ppt,pptx,xls,xlsx的文件都归为文档列表中. 系列 ...

随机推荐

  1. laravel 5.5 在构造函数使用Session

    public function __construct() { $this->request = request(); // 验证是否登录 $this->middleware(functi ...

  2. nginx优化--gzip压缩与expire浏览器缓存

    gzip压缩 概述 网页在服务器端经过了gzip或者其他格式的压缩后的输出明显减少了content-length字节,当访问过百万时,这些减少的字节就会变为客观的流量给节约下来;从而减轻服务器的压力以 ...

  3. Meeting HDU - 5521 虚点建图

    Problem Description Bessie and her friend Elsie decide to have a meeting. However, after Farmer John ...

  4. 查看git拉取地址

    在项目地址下面输入:git remote -v 即可查看到地址啦.

  5. SQL Server 2008如何开启数据库的远程连接

    SQL Server 2008默认是不允许远程连接的,如果想要在本地用SSMS连接远程服务器上的SQL Server 2008,远程连接数据库.需要做两个部分的配置: 1,SQL Server Man ...

  6. 0UE3 材质概要

    材质概要 概述 参数 当创建材质时如何考虑颜色 材质表达式 Abs(求绝对值) 添加 AntialiasedTextureMask AppendVector(向量合并) BumpOffset(凸凹偏移 ...

  7. Productivity tips, tricks and hacks for academics (2015 edition)

    Productivity tips, tricks and hacks for academics (2015 edition) Contents Jump to: My philosophy: Op ...

  8. jQuery各版本CDN

    jquery-2.1.1 注:jquery-2.0以上版本不再支持IE 6/7/8)百度引用地址 (推荐目前最稳定的,不会出现延时打不开情况) 百度压缩版引用地址:<script src=”ht ...

  9. 从零搭建SSM框架(二)运行工程

    启动cnki-manager工程 1.需要在cnki-manager 的pom工程中,配置tomcat插件.启动的端口号,和工程名称. 在cnki-manager的pom文件中添加如下配置: < ...

  10. Spring boot初始

    1 创建pom.xml parent:org.springframework.boot  包含启动的依赖 添加依赖,如 spring-boot-starter-web mvn dependency:t ...