/* * Copyright 2019-2020 Zheng Jie * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package admin.modules.security.service; import admin.exception.BadRequestException; import admin.exception.EntityNotFoundException; import admin.modules.security.config.bean.LoginProperties; import admin.modules.security.service.dto.JwtUserDto; import admin.modules.system.service.DataService; import admin.modules.system.service.RoleService; import admin.modules.system.service.UserService; import admin.modules.system.service.dto.UserDto; import lombok.RequiredArgsConstructor; import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.stereotype.Service; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; /** * @date 2018-11-22 */ @RequiredArgsConstructor @Service("userDetailsService") public class UserDetailsServiceImpl implements UserDetailsService { private final UserService userService; private final RoleService roleService; private final DataService dataService; private final LoginProperties loginProperties; public void setEnableCache(boolean enableCache) { this.loginProperties.setCacheEnable(enableCache); } /** * 用户信息缓存 * * @see {@link UserCacheClean} */ static Map<String, JwtUserDto> userDtoCache = new ConcurrentHashMap<>(); @Override public JwtUserDto loadUserByUsername(String username) { boolean searchDb = true; JwtUserDto jwtUserDto = null; if (loginProperties.isCacheEnable() && userDtoCache.containsKey(username)) { jwtUserDto = userDtoCache.get(username); searchDb = false; } if (searchDb) { UserDto user; try { user = userService.findByName(username); } catch (EntityNotFoundException e) { // SpringSecurity会自动转换UsernameNotFoundException为BadCredentialsException throw new UsernameNotFoundException("", e); } if (user == null) { throw new UsernameNotFoundException(""); } else { if (!user.getEnabled()) { throw new BadRequestException("账号未激活"); } jwtUserDto = new JwtUserDto("", user, dataService.getDeptIds(user), roleService.mapToGrantedAuthorities(user) ); userDtoCache.put(username, jwtUserDto); } } return jwtUserDto; } public UserDto getUserByPhone(String phone){ UserDto user; try { user = userService.findByPhone(phone); } catch (EntityNotFoundException e) { // SpringSecurity会自动转换UsernameNotFoundException为BadCredentialsException throw new UsernameNotFoundException("", e); } return user; } }