Ejemplo n.º 1
0
        /// <summary>
        /// 登录
        /// </summary>
        /// <param name="user">用户</param>
        /// <param name="password">密码</param>
        /// <param name="isPersistent">cookie是否持久保留,设置为false,当关闭浏览器则cookie失效</param>
        /// <param name="lockoutOnFailure">达到登录失败次数是否锁定</param>
        public async Task <SignInResult> SignInAsync(User user, string password, bool isPersistent, bool lockoutOnFailure)
        {
            if (user == null)
            {
                return(new SignInResult(SignInState.Failed, null, GreatWallResource.InvalidAccountOrPassword));
            }
            var signInResult = await IdentitySignInManager.PasswordSignInAsync(user, password, isPersistent, lockoutOnFailure);

            return(GetSignInResult(user, signInResult));
        }
Ejemplo n.º 2
0
        /// <summary>
        /// 密码登录
        /// </summary>
        private async Task <SignInResult> PasswordSignIn(User user, string password, bool isPersistent, bool lockoutOnFailure)
        {
            var signInResult = await IdentitySignInManager.PasswordSignInAsync(user, password, isPersistent, lockoutOnFailure);

            if (signInResult.IsNotAllowed)
            {
                return(new SignInResult(SignInState.Failed, null, GreatWallResource.UserIsDisabled));
            }
            if (signInResult.IsLockedOut)
            {
                return(new SignInResult(SignInState.Failed, null, GreatWallResource.LoginFailLock));
            }
            if (signInResult.Succeeded)
            {
                return(new SignInResult(SignInState.Succeeded, user.Id.SafeString()));
            }
            if (signInResult.RequiresTwoFactor)
            {
                return(new SignInResult(SignInState.TwoFactor, user.Id.SafeString()));
            }
            return(new SignInResult(SignInState.Failed, null, GreatWallResource.InvalidAccountOrPassword));
        }