LoginUserCheckBLL.cs 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. using Newtonsoft.Json;
  2. using SqlSugar;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Reflection;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using WMS.BZModels.Models.UserCenterManager;
  10. using WMS.BZUtil;
  11. using WMS.Info;
  12. using WMS.BZSqlSugar;
  13. using WMS.Util;
  14. namespace WMS.BZServices
  15. {
  16. public class BZLoginUserCheckBLL : IBLL
  17. {
  18. private static Repository<AclUsertoken> _aclUsertokenRepository => new Repository<AclUsertoken>();
  19. private static Repository<AclUserInfo> _acluserInfoRepository => new Repository<AclUserInfo>();
  20. public string InJsonData { get; set; }
  21. public object OutObjData { get; set; }
  22. public string SuccessMsg { get; set; } = "登录成功。";
  23. public LoginUserInfo LoginUser { get; set; }
  24. public string BLLDesc { get; private set; } = "用户登录";
  25. public void Exec()
  26. {
  27. try
  28. {
  29. LoginInfo LoginData = JsonConvert.DeserializeObject<LoginInfo>(InJsonData);
  30. if (LoginData == null)
  31. {
  32. throw BZSysExCore.ThrowInEmpty();
  33. }
  34. if (LoginUser.AppType == EAppType.PC)
  35. {
  36. BZSessionCookieCore.CheckVerifyCode(LoginData.TextV);
  37. }
  38. void action()
  39. {
  40. LoginUser.UserNo = LoginData.TextU;
  41. LoginUser.WAreaNoList = LoginData.WAreaNoList;
  42. //LoginUser.WarehouseNo = LoginData.WarehouseNo;
  43. var tmpuser = BZLoginBLLCore.CheckLoginUser(LoginData.TextU, LoginData.TextP, LoginUser.AppType, LoginData.WarehouseNo, LoginData.WAreaNoList);
  44. LoginUser.UserName = tmpuser.Name;
  45. LoginUser.UserNo = tmpuser.Code;
  46. LoginUser.WarehouseNo = tmpuser.WarehouseNo;
  47. LoginUser.UserType = BZLoginBLLCore.GetUserType(tmpuser.Code);
  48. //判断用户是在离线,如果离线作业,其他不能登录。
  49. if (ConfigHelper.GetConfig().IsSSO)
  50. {
  51. if (_aclUsertokenRepository.Queryable().Count(it => it.UserNo == tmpuser.Code && it.AppTypeNum == (int)EAppType.OffLineRF) > 0)
  52. throw BZSysExCore.ThrowFailException("此用户已离线登录,无法再次登录。");
  53. }
  54. if (LoginUser.AppType == EAppType.OffLineRF)
  55. {
  56. if (BZLoginBLLCore.CheckAdmin(tmpuser.Code))
  57. throw BZSysExCore.ThrowFailException("管理员用户无法进行离线操作。");
  58. //判断离线仓库和区域是否已经被锁定
  59. //var waslist = ctx.Queryable<ACL_USERTOKEN>().Where(it => it.F_WAREHOUSENO == LoginData.WarehouseNo && it.F_APPTYPENUM == (int)EAppType.OffLineRF).ToList();
  60. //if (waslist != null && waslist.Count > 0)
  61. //{
  62. // List<string> wlist = new List<string>();
  63. // foreach (var w in waslist)
  64. // {
  65. // if (string.IsNullOrWhiteSpace(w.F_WAREANOLIST))
  66. // continue;
  67. // wlist.AddRange((w.F_WAREANOLIST).ToObject<List<string>>());
  68. // }
  69. // if (LoginData.WAreaNoList.Any(it => wlist.Contains(it)))
  70. // throw BZSysExCore.ThrowFailException("区域已经被锁定。");
  71. //}
  72. }
  73. else
  74. {
  75. //if (SysSetCore.GetSysSet().IsOnlyLogin)
  76. // //删除以前登录信息
  77. // _aclUsertokenRepository.Deleteable().Where(it => it.UserNo == tmpuser.Code).ExecuteCommand();
  78. //else
  79. //删除以前登录信息
  80. if (ConfigHelper.GetConfig().IsSSO)
  81. {
  82. _aclUsertokenRepository.Deleteable().Where(it => it.UserNo == tmpuser.Code && it.AppTypeNum == (int)LoginUser.AppType).ExecuteCommand();
  83. }
  84. }
  85. _acluserInfoRepository.UpdateModelColumns(p => new AclUserInfo
  86. {
  87. EditWho = tmpuser.Code,
  88. EditTime = DateTime.Now,
  89. PwdErrQty = 0
  90. }, it => it.Code.ToUpper() == tmpuser.Code.ToUpper());
  91. //初始化登录信息
  92. DateTime nowdt = DateTime.Now;
  93. string TokenNo = Guid.NewGuid().ToString();
  94. if (ConfigHelper.GetConfig().IsSSO)
  95. {
  96. var tmpobj = new AclUsertoken
  97. {
  98. Code = TokenNo,
  99. AppTypeNum = (int)LoginUser.AppType,
  100. BTime = nowdt,
  101. ETime = (LoginUser.AppType == EAppType.OffLineRF) ? DateTime.MaxValue : nowdt,
  102. IPAddress = LoginUser.IPAddress,
  103. UserNo = tmpuser.Code,
  104. //WareaNoList = LoginUser.WAreaNoList.ToJson(),
  105. WarehouseNo = LoginUser.WarehouseNo,
  106. UserName = tmpuser.Name,
  107. AppDeviceNo = LoginUser.AppDeviceNo
  108. };
  109. if (_aclUsertokenRepository.Insert(tmpobj) <= 0)
  110. {
  111. throw BZSysExCore.ThrowFailException("记录登录信息失败,请重试。");
  112. }
  113. }
  114. string EncryptTokenNo = SysSecurityHelp.Aes256Encrypt(TokenNo);
  115. if (LoginUser.AppType == EAppType.PC)
  116. {
  117. BZSessionCookieCore.AddLoginToken(EncryptTokenNo);
  118. }
  119. LoginUser.LoginTime = nowdt;
  120. LoginUser.EncryptTokenNo = EncryptTokenNo;
  121. LoginUser.JWTToken = new Operator().EncodeToken(LoginUser.UserNo, LoginUser.UserName, LoginData.TextU, EncryptTokenNo, LoginUser.WarehouseNo);
  122. OutObjData = LoginUser;
  123. }
  124. _acluserInfoRepository.LoginUseTran(action);
  125. }
  126. catch (Exception ex)
  127. {
  128. if (ex is BZSysExCore)
  129. {
  130. BZSysExCore exc = ex as BZSysExCore;
  131. if (exc != null && exc.SysExType == ESysExType.PwdError)
  132. {
  133. BZLoginBLLCore.UpdatePwdErr(LoginUser.UserNo);
  134. BZSessionCookieCore.LoginPwdErrAdd();
  135. }
  136. }
  137. OutObjData = BZSessionCookieCore.GetUserPwdErrorNum();
  138. throw ex;
  139. }
  140. }
  141. }
  142. }