Пример #1
0
        public override void OnActionExecuting(ActionExecutingContext context)
        {
            try
            {
                string strToken = "";
                if (Request.Headers.TryGetValue("x-access-token", out StringValues token))
                {
                    strToken = token.ToString();
                }
                var userInfo = Utility.Tools.TokenUtils.ToObject <UserTokenInfoModel>(strToken);

                userTokenInfo = userInfo;
            }
            catch (Exception)
            {
            }
            base.OnActionExecuting(context);
        }
Пример #2
0
        public async Task <IActionResult> LoginIn(LoginModel model)
        {
            try
            {
                var _user = new UserTokenInfoModel();

                if (string.IsNullOrEmpty(model.ProjectCode))
                {
                    if (model.UserName.ToLower() == "system")
                    {
                        if (model.Password == "123456")
                        {
                            _user.UserId = _user.RoleId = "System";
                        }
                        else
                        {
                            return(BadRequest(new { type = 0, message = "密码错误,请重新输入!" }));
                        }
                    }
                    else
                    {
                        var user = await sysUserBll.GetEntityAsync(u => u.Account == model.UserName);

                        if (user == null)
                        {
                            return(BadRequest(new { type = 0, message = "用户名错误或用户名不存在,请重新输入!" }));
                        }
                        else
                        {
                            var paw = Utility.Tools.MD5Utils.Sign(model.Password, user.Secretkey);
                            if (user.Password != paw)
                            {
                                return(BadRequest(new { type = 0, message = "密码错误,请重新输入!" }));
                            }
                        }
                        _user        = Utility.Tools.MapperUtils.MapTo <User, UserTokenInfoModel>(user);
                        _user.RoleId = "PrjManager";
                    }
                }
                else
                {
                    var entity = await userProjectBll.GetEntityAsync(p => p.PrjIdentification == model.ProjectCode);

                    if (entity == null)
                    {
                        return(BadRequest(new { type = 0, message = "项目代码有误或不存在,请重新输入!" }));
                    }

                    if (string.IsNullOrEmpty(entity.PrjDataBase))
                    {
                        return(BadRequest(new { type = 0, message = "出错了,请稍后重试!" }));
                    }

                    var user = await prjUserBll.GetEntityAsync(u => u.Account == model.UserName, entity.PrjDataBase);

                    if (user == null)
                    {
                        return(BadRequest(new { type = 0, message = "用户名错误或用户名不存在,请重新输入!" }));
                    }
                    else
                    {
                        var paw = Utility.Tools.MD5Utils.Sign(model.Password, user.Secretkey);
                        if (user.Password != paw)
                        {
                            return(BadRequest(new { type = 0, message = "密码错误,请重新输入!" }));
                        }
                    }

                    if (user.EnabledMark == 0)
                    {
                        return(BadRequest(new { type = 0, message = "该角色已被锁定,请联系管理员解锁" }));
                    }

                    _user = Utility.Tools.MapperUtils.MapTo <RoadManageSystem.Models.ProjectModel.User, UserTokenInfoModel>(user);
                    _user.DataBaseName = entity.PrjDataBase;
                }
                _user.TokenExpiration = DateTime.Now.AddDays(1);

                string token = Utility.Tools.TokenUtils.ToToken(_user);

                return(Ok(new { type = 1, token }));
            }
            catch (Exception)
            {
                return(BadRequest(new { type = 0, message = "出错了,请稍后重试!" }));
            }
        }