第一步,在SqlServer数据库中创建存储过程,查询的是用户名(员工姓名)所扮演的角色:

if exists(select * from sys.objects where name='proc_select_Login')
begin
drop procedure proc_select_Login
end
go
create procedure proc_select_Login
@ename nvarchar(), --用户名
@epwd nvarchar() --密码
as
select j.JName from EmployInfo,JobInfo j where EName=@ename and EPwd=@epwd
go

第二步,在Model中业务逻辑EmployeeDao类下创建SelectLogin方法,使用ExecuteScalar()方法查询出用户名(员工姓名)的角色,返回的是字符串类型:

 /// <summary>
/// 管理员登录
/// </summary>
/// <param name="ename"></param>
/// <param name="epwd"></param>
/// <returns></returns>
public string SelectLogin(string ename, string epwd)
{
string sql = "proc_select_Login";
SqlCommand cmd = new SqlCommand(sql, con);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@ename", ename);
cmd.Parameters.AddWithValue("@epwd", epwd);
con.Open();
string jName = string.Empty;
jName = Convert.ToString(cmd.ExecuteScalar());
con.Close();
return jName;
}

第三步,在Controller控制器中创建名称为EmployeeController的.cs文件,调用EmployeeDao类下SelectLogin()方法,进行员工登录验证。登录成功,进行页面跳转,并把用户名(员工姓名)和其角色存储到Session中,

注意:string txtCheck 是接受页面中写入的验证码,且与页面中验证码input标签中的name必须一致。

/// <summary>
/// 员工登录验证
/// </summary>
/// <param name="collection"></param>
/// <param name="txtCheck">验证码</param>
/// <returns></returns>
[HttpPost]
public ActionResult Login(FormCollection collection,string txtCheck)
{ //接收页面输入的用户名和密码
employ.EName = collection["txtname"];
employ.EPwd = collection["txtpwd"]; string str = Convert.ToString(this.TempData["Code"]).ToLower();//接收存在临时数据中的验证码
string jName = dao.SelectLogin(employ.EName, employ.EPwd); if (jName!=string.Empty)
{
if (str != txtCheck.ToLower())
{
ViewBag.ErrorMsg = "验证码错误";
return View(employ);
}
else
{
//使用Session进行储存
this.Session["eName"] = employ.EName; //使用session进行储存
this.Session["jName"] = jName; //this.Session.Add("employ", employ);
return RedirectToAction("Index", "Home");
}
}
else
{
ViewBag.ErrorMsg = "用户名或密码错误";
return View(employ);
}
}
}

第四步,创建登录页面,我这里嵌入的是html代码:

<body>
<form action="/Employee/Login" method="post">
<table border="" align="center" cellpadding="" cellspacing="" style=" margin-top:150px;">
<tr>
<td width="31%" height="" class="login-text02">
用户名:<br />
</td>
<td width="69%">
<input type="text" name="txtname" id="txtname" @*value="@Model.EName" *@/>
</td>
</tr>
<tr>
<td height="" class="login-text02">
密 码:<br />
</td>
<td>
<input type="password" name="txtpwd" id="txtpwd" @*value="@Model.EPwd"*@ />
</td>
</tr>
<tr>
<td height="" class="login-text02">
验证码:<br />
</td>
<td>
<div style="width:400px;">
<input type="text" name="txtCheck" />&nbsp;&nbsp;&nbsp;
<img id="valiCode" style="cursor: pointer;" src="/ValidateCodeImg/Get" title="看不清,点击换一张" alt="看不清?请点我" onclick="imgCodes(this);" />
&nbsp;&nbsp;
<a href="javascript:imgCodes();">看不清楚,点击这里</a> </div>
</td>
</tr>
<tr>
<td height="">
&nbsp;
</td>
<td>
<input type="submit" id="btnlogin" value="登录" class="btn btn-success"/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<input type="reset" value="重 置" class="btn btn-warning"/>
<label style="color:Red;">@ViewBag.ErrorMsg</label>
</td>
</tr>
</table>
</form>
</body>

第五步,在Controller中创建控制器命名为HomeController,接受之前Session中存储的用户和其角色:

 public ActionResult Top(FormCollection collecton)
{ string eName = Convert.ToString(this.Session["eName"]);//接收存在session中的验证码 string jName = this.Session["jName"].ToString();
return View();
}

第六步,为HomeController创建页面,绑定Session中存储的存储的用户名和其角色:

<table width="100%" border="" cellspacing="" cellpadding="">
<tr>
<td>
<img src="@Url.Content("~/Content/images/uesr.gif")" width="" height="">
<span class="STYLE2">
当前登录用户:@if (Session["eName"] != null)
{
<span>@Session["eName"].ToString()</span> }&nbsp;&nbsp;&nbsp;&nbsp;
角色:@if (Session["jName"]!=null)
{
<span>@Session["jName"].ToString()</span>
}
</span>
</td>
</tr>
</table>

显示结果:

在mvc中将session的值绑定在页面上的更多相关文章

  1. jquery代码修改input的value值,而页面上input框的值没有改变的解决办法

    问题描述: 在搜索框中输入一些字符,并且点击搜索框右边的五角星做收藏操作时,打开的弹框中Save Search:后面的input中的值被赋值了外面搜索框的值,但是当此次操作完成之后,再次做同样的操作, ...

  2. Spring MVC中Session的正确用法<转>

    Spring MVC是个非常优秀的框架,其优秀之处继承自Spring本身依赖注入(Dependency Injection)的强大的模块化和可配置性,其设计处处透露着易用性.可复用性与易集成性.优良的 ...

  3. ASP.NET MVC之Session State性能问题(七)

    前言 这一节翻译一篇有关Session State性能问题的文章,非一字一句翻译. 话题 不知道我们在真实环境中是否用到了Session State特性,它主要用来当在同一浏览器发出多个请求时来存储数 ...

  4. 【转】Spring MVC中Session的正确用法之我见

    Spring MVC是个非常优秀的框架,其优秀之处继承自Spring本身依赖注入(Dependency Injection)的强大的模块化和可配置性,其设计处处透露着易用性.可复用性与易集成性.优良的 ...

  5. ASP.NET MVC中默认Model Binder绑定Action参数为List、Dictionary等集合的实例

    在实际的ASP.NET mvc项目开发中,有时会遇到一个参数是一个List.Dictionary等集合类型的情况,默认的情况ASP.NET MVC框架是怎么为我们绑定ASP.NET MVC的Actio ...

  6. Asp.net Mvc 自定义Session (二)

    在 Asp.net Mvc 自定义Session (一)中我们把数据缓存工具类写好了,今天在我们在这篇把 剩下的自定义Session写完 首先还请大家跟着我的思路一步步的来实现,既然我们要自定义Ses ...

  7. MVC之Session State性能

    ASP.NET MVC之Session State性能问题(七)   前言 这一节翻译一篇有关Session State性能问题的文章,非一字一句翻译. 话题 不知道我们在真实环境中是否用到了Sess ...

  8. Spring MVC中Session的正确用法之我见

    Spring MVC是个非常优秀的框架,其优秀之处继承自Spring本身依赖注入(Dependency Injection)的强大的模块化和可配置性,其设计处处透露着易用性.可复用性与易集成性.优良的 ...

  9. MVC框架中的值提供机制(三)

    在MVC框架中NameValueCollectionValueProvider采用一个NameValueCollection作为数据源,DictionnaryValueProvider的数据源类型自然 ...

随机推荐

  1. testng 教程

    Testng 简介: Testng是一套开源测试框架,是从Junit继承而来,testng意为test next generation,主要有以下特性: annotations  注释,如 @test ...

  2. iOS compare 字符串比较

    NSString 比较字符串,我介绍一些常用的方法: NSString *value = @"1234567890"; 比较的方法: [value compare:(NSStrin ...

  3. C Primer Plus_第5章_运算符、表达式和语句_编程练习

    Practice 1. 输入分钟输出对应的小时和分钟. #include #define MIN_PER_H 60 int main(void) { int mins, hours, minutes; ...

  4. 第一天:安装nodejs

    1.首先,下载NodeJs程序.地址 http://www.nodejs.org/download/,选择Windows Installer 64bit 2.下载下来后,狂点下一步,安装在本地硬盘上. ...

  5. 在新机器部署Qt+mysql程序

    1.一般情况下需要将Qt5Core.dll,Qt5Gui.dll,Qt5Sql.dll,Qt5Widgets.dll,platforms\qwindows.dll msvcp120.dll,msvcp ...

  6. sql单表中某一字段重复,取最近3条或几条数据

    order by a.uid,a.id; sql查询语句,针对需求:一个表中某一字段是有重复的数据,针对该字段相同的值只取最近的3条或要求的几条: --记录铭心!

  7. 了解Solr6.1结构及实现原理

    Solr是一个高性能,采用Java5开发,基于Lucene的全文搜索服务器.同时对其进行了扩展,提供了比Lucene更为丰富的查询语言,同时实现了可配置.可扩展并对查询性能进行了优化,并且提供了一个完 ...

  8. 图像处理中的matlab使用

    图像的矩阵表示 类和图像类型 虽然使用的是整数坐标, 但 MATLAB 中的像素值(亮度)并未限制为整数. 表 1-1 列出了 MATLAB 和图像处理工具箱为描述像素值而支持的各种类. 表中的前 8 ...

  9. oracle RAC切换归档

    (转自leshami)    RAC环境下的归档模式切换与单实例稍有不同,主要是共享存储所产生的差异.在这种情况下,我们可以将RAC数据库切换到非集群状态下,仅仅在一个实例上来实施归档模式切换即可完成 ...

  10. WCF服务承载(笔记)

    自托管(也做自承载) 承载 WCF 服务最灵活.最便捷的方法就是进行自承载.要能够自承载服务,必须满足两个条件.第一,需要 WCF 运行时:第二,需要可以承载 ServiceHost 的托管 .NET ...