diff --git a/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserBLL.cs b/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserBLL.cs
index d7ee5a89f..28166cfc8 100644
--- a/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserBLL.cs
+++ b/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserBLL.cs
@@ -1201,6 +1201,31 @@ namespace Learun.Application.Organization
}
}
+
+ ///
+ /// 修改用户的允许登录结束时间
+ ///
+ /// 主键值
+ /// 状态:1-赋值;0-重置
+ public void UpdateAllowEndTime(string keyValue, int state)
+ {
+ try
+ {
+ userService.UpdateAllowEndTime(keyValue, state);
+ }
+ catch (Exception ex)
+ {
+ if (ex is ExceptionEx)
+ {
+ throw;
+ }
+ else
+ {
+ throw ExceptionEx.ThrowBusinessException(ex);
+ }
+ }
+ }
+
/////
///// 获取用户头像
/////
diff --git a/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserIBLL.cs b/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserIBLL.cs
index 105763e06..fe666353f 100644
--- a/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserIBLL.cs
+++ b/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserIBLL.cs
@@ -195,5 +195,12 @@ namespace Learun.Application.Organization
void UpdateIp(string ip, string id);
void GetImgForDC(string userId);
UserEntity GetEntityByWeixinOpenIdPC(string openId);
+
+ ///
+ /// 修改用户的允许登录结束时间
+ ///
+ /// 主键值
+ /// 状态:1-赋值;0-重置
+ void UpdateAllowEndTime(string keyValue, int state);
}
}
diff --git a/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserService.cs b/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserService.cs
index c3bd4ab11..12f3ce4bc 100644
--- a/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserService.cs
+++ b/Learun.Framework.Ultimate V7/Learun.Application.Organization/User/UserService.cs
@@ -848,6 +848,38 @@ namespace Learun.Application.Organization
}
}
}
+
+ ///
+ /// 修改用户的允许登录结束时间
+ ///
+ /// 主键值
+ /// 状态:1-赋值;0-重置
+ public void UpdateAllowEndTime(string keyValue, int state)
+ {
+ try
+ {
+ if (state == 0)
+ {
+ this.BaseRepository().ExecuteBySql("update LR_Base_User set F_AllowEndTime=null where F_UserId='" + keyValue + "'");
+ }
+ else
+ {
+ this.BaseRepository().ExecuteBySql("update LR_Base_User set F_AllowEndTime='" + DateTime.Now + "' where F_UserId='" + keyValue + "'");
+ }
+ }
+ catch (Exception ex)
+ {
+ if (ex is ExceptionEx)
+ {
+ throw;
+ }
+ else
+ {
+ throw ExceptionEx.ThrowServiceException(ex);
+ }
+ }
+ }
+
}
}
diff --git a/Learun.Framework.Ultimate V7/Learun.Application.Web/Controllers/LoginController.cs b/Learun.Framework.Ultimate V7/Learun.Application.Web/Controllers/LoginController.cs
index 58f0e81e4..32fd91b1c 100644
--- a/Learun.Framework.Ultimate V7/Learun.Application.Web/Controllers/LoginController.cs
+++ b/Learun.Framework.Ultimate V7/Learun.Application.Web/Controllers/LoginController.cs
@@ -38,6 +38,7 @@ namespace Learun.Application.Web.Controllers
private LoginModelIBLL loginModelIbll = new LoginModelBLL();
private AnnexesFileIBLL annexesFileIbll = new AnnexesFileBLL();
WeChatDevelopIBLL weChatDevelopIbll = new WeChatDevelopBLL();
+ private Sys_DefaultPwdConfigIBLL sys_DefaultPwdConfigIBLL = new Sys_DefaultPwdConfigBLL();
#endregion
#region 视图功能
@@ -184,6 +185,15 @@ namespace Learun.Application.Web.Controllers
}
//获取错误次数
ViewBag.errornum = OperatorHelper.Instance.GetCurrentErrorNum();
+ //获取初始密码设置中已启用的密码
+ ViewBag.IsSetDefaultPwd = false;
+ ViewBag.DefaultPwd = "";
+ var defaultPwdEntity = sys_DefaultPwdConfigIBLL.GetEnabledEntity();
+ if (defaultPwdEntity != null)
+ {
+ ViewBag.IsSetDefaultPwd = true;
+ ViewBag.DefaultPwd = defaultPwdEntity.Pwd;
+ }
//获取高职版跳转地址
ViewBag.DigitalschoolMisLoginurl = ConfigurationManager.AppSettings["DigitalschoolMisLoginurl"];
ViewBag.Returnurl = "http://" + Request.Url.Host + ":" + Request.Url.Port;
@@ -499,11 +509,13 @@ namespace Learun.Application.Web.Controllers
/// 用户名
/// 密码
/// 验证码
+ /// 密码是否是强密码
+ /// 密码是否是初始密码,是则需要提示(true)
///
[HttpPost]
[AjaxOnly]
[HandlerValidateAntiForgeryToken]
- public ActionResult CheckLogin(string username, string password, string verifycode, string up)
+ public ActionResult CheckLogin(string username, string password, string verifycode, string up, string defaultPwdTip)
{
int error = OperatorHelper.Instance.GetCurrentErrorNum();
@@ -521,6 +533,41 @@ namespace Learun.Application.Web.Controllers
#region 内部账户验证
UserEntity userEntity = userBll.CheckLogin(username, password);
+ #region 登录次数限制,禁止登录时间限制
+ int defaultForbidLoginNum = 5;//默认的禁止登录次数
+ double defaultForbidLoginMinutes = 10;//默认的禁止登录分钟数
+ if (!string.IsNullOrEmpty(Config.GetValue("ForbidLoginNum")))
+ {
+ defaultForbidLoginNum = Config.GetValue("ForbidLoginNum").ToInt();
+ }
+ if (!string.IsNullOrEmpty(Config.GetValue("ForbidLoginMinutes")))
+ {
+ defaultForbidLoginMinutes = Config.GetValue("ForbidLoginMinutes").ToDouble();
+ }
+ //错误次数大于等于5时,判断禁止登录时间是否超过10分钟:若是则修改用户的允许登录结束时间,可以登录;若否,禁止登录;
+ if (error >= defaultForbidLoginNum)
+ {
+ if (userEntity.LoginOk)//登录成功
+ {
+ if (userEntity.F_AllowEndTime.HasValue)
+ {
+ var period = (DateTime.Now - userEntity.F_AllowEndTime.Value).TotalMinutes;
+ if (period >= defaultForbidLoginMinutes)
+ {
+ userBll.UpdateAllowEndTime(userEntity.F_UserId, 0);
+ }
+ else
+ {
+ return Fail("错误次数超过" + defaultForbidLoginNum + "次,已被禁止登录,请" + defaultForbidLoginMinutes + "分钟后重试!", error);
+ }
+ }
+ }
+ else//登录失败
+ {
+ return Fail(userEntity.LoginMsg, error);
+ }
+ }
+ #endregion
#region 写入日志
LogEntity logEntity = new LogEntity();
@@ -540,6 +587,11 @@ namespace Learun.Application.Web.Controllers
logEntity.F_ExecuteResultJson = "登录失败:" + userEntity.LoginMsg;
logEntity.WriteLog();
int num = OperatorHelper.Instance.AddCurrentErrorNum();
+ //判断登录错误次数大于等于5,修改用户的允许登录结束时间;
+ if (num >= defaultForbidLoginNum)
+ {
+ userBll.UpdateAllowEndTime(userEntity.F_UserId, 1);
+ }
return Fail(userEntity.LoginMsg, num);
}
else
@@ -552,12 +604,15 @@ namespace Learun.Application.Web.Controllers
logEntity.F_ExecuteResultJson = "登录成功";
logEntity.WriteLog();
OperatorHelper.Instance.ClearCurrentErrorNum();
+ //修改用户的允许登录结束时间;
+ userBll.UpdateAllowEndTime(userEntity.F_UserId, 0);
//是否强密码验证
if (!string.IsNullOrEmpty(ConfigurationManager.AppSettings["verifypwd"]) && ConfigurationManager.AppSettings["verifypwd"] == "true" && up == "false")
{
- return Success(new { pwd = true });
+ return Success(new { pwd = true, pwdtip = defaultPwdTip == "true" ? true : false });
}
- return Success("登录成功");
+ //返回成功的数据(pwdtip:初始密码提示弹框;pwd:弱密码修改弹框;)
+ return Success("登录成功", new { pwdtip = defaultPwdTip == "true" ? true : false });
}
#endregion
}
@@ -899,8 +954,8 @@ namespace Learun.Application.Web.Controllers
{
string appid = "76d40062-349f-486d-b871-35bed08d2f59";
string secret = "cgpi";
- string appkey =Request.QueryString["appkey"];
- string response = Util.HttpMethods.HttpGet("http://localhost:20472/SSOSystem/authorize?appid=" + appid + "&secret=" + secret + "&appkey="+ appkey);
+ string appkey = Request.QueryString["appkey"];
+ string response = Util.HttpMethods.HttpGet("http://localhost:20472/SSOSystem/authorize?appid=" + appid + "&secret=" + secret + "&appkey=" + appkey);
return Content(response);
}
diff --git a/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Home/AdminDefault/index.js b/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Home/AdminDefault/index.js
index 928cc635c..303c001e6 100644
--- a/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Home/AdminDefault/index.js
+++ b/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Home/AdminDefault/index.js
@@ -6,7 +6,9 @@
* 描 述:经典风格皮肤
*/
var autoopenid = request('autoopen');
-var pwd = request("pwd");
+var pwd = request("pwd");//弱密码修改弹框
+var pwdtip = request("pwdtip");//初始密码提示弹框
+var pwdpwdtip = request("pwdpwdtip");//弱密码修改弹框&初始密码提示弹框
var bootstrap = function ($, learun) {
"use strict";
// 菜单操作
@@ -197,7 +199,8 @@ var bootstrap = function ($, learun) {
// area: ['500px', '300px']
// });
//}
- if (pwd == "true") {
+ //弱密码修改弹框
+ if (pwd == "true" || pwdpwdtip == "true") {
top.layer.open({
id: 'pwdform',
title: '密码修改',
@@ -225,6 +228,10 @@ var bootstrap = function ($, learun) {
}
});
}
+ //初始密码提示弹框
+ if (pwdtip == "true" || pwdpwdtip == "true") {
+ learun.layerConfirm('当前登录密码还是初始密码!', function (res) { });
+ }
//上网认证
if (ACIp != null && ACIp != "") {
//Ip上网
diff --git a/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Login/Default.cshtml b/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Login/Default.cshtml
index 72179e6e4..88f5c754f 100644
--- a/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Login/Default.cshtml
+++ b/Learun.Framework.Ultimate V7/Learun.Application.Web/Views/Login/Default.cshtml
@@ -49,6 +49,8 @@
+
+
@@ -59,7 +61,7 @@
@if (ViewBag.WeixinLoginSwitch)
{
-
+
使用微信登录
}
@@ -121,14 +123,14 @@
-