开发工具与关键技术: Visual Studio 验证码
作者:黎凤焕
撰写时间:2019年 5月 30 日
做登录页面的时候,一般都会使用验证码来登录的,经过验证码的判断是否正确,还判断账号与密码是否正确,经过多处判断信息的准确性才可以登录进去。验证码的长度自定义的,一般验证码的长度为4到8位数。
如果验证码太长,用户的体验程度有影响,浪费用户的时间,或者用户输入验证码的时候输入错误了,又得重新输入一串长长的验证码。验证码一般长度为5比较合适,通过写方法的形式,生成长度为5的随机的验证码字符串,然后根据生成的验证码字符串生成 验证码图片,将验证码字符串存入session中,把图片返回到视图(文件内容,文件格式)。
public ActionResult CreateValidCodeImage()
{
//1、生成长度为5的随机的验证码字符串
string strRandom = ValidCodeUtils.GetRandomCode(5);
//2、根据生成的验证码字符串生成 验证码图片
byte[] imgByte = ValidCodeUtils.CreateImage(strRandom);
//3、将验证码字符串存入session中 key值为
Session[“validCode”] = strRandom;
//4、把图片返回到视图(文件内容,文件格式);
return File(imgByte, @“image/jpeg”);
}
//计算登录时长
public ActionResult GetLoginTimes()
{
try
{
//获取Session中的时间//获取登录那一刻的时间
string loginTime = Session["ServerTime"].ToString();
//转为datetime
DateTime dateTimeLogin = Convert.ToDateTime(loginTime);
DateTime dateTimeNow = DateTime.Now;//获取当前时间
//求时间差
TimeSpan ts = dateTimeNow - dateTimeLogin;
//声明返回变量
string str = "";
if (ts.Hours > 0)
{
str = ts.Hours.ToString() + "小时 " + ts.Minutes.ToString() + "分钟 " + ts.Seconds + "秒";//x小时x分钟x秒
}
if (ts.Hours == 0 && ts.Minutes > 0)
{
str = ts.Minutes.ToString() + "分钟 " + ts.Seconds + "秒";//x分钟x秒
}
if (ts.Hours == 0 && ts.Minutes == 0)
{
str = ts.Seconds + "秒";//x秒
}
return Json(str, JsonRequestBehavior.AllowGet);
}
catch (Exception)
{
//重定向到登录页面
return Redirect("/Main/Login");
}
}
登录进入主页面的时候,可以设置登录的时长,记录登录了多才长时间。首先获取Session中的时间或者获取登录那一刻的时间转化为datetime的形式。
).Single();//查询单条数据,当没有数据或者有多条数据时会触发异常
.ToList();//查询多条数据并转为List
.Count();//查询数据总数