UserDetailsService :: Spring Security

DaoAuthenticationProvider 에 의해 사용된다. username, password를 반환하지만 인증에 필요한 추가 정보들을 더 반환하도록 구현체를 만들어 커스텀할 수 있다.


커스텀 예시 코드만 남긴다.

package kr.co.rland.boot3_api.auth.service;

import kr.co.rland.boot3_api.anonymous.member.repository.MemberRepository;
import kr.co.rland.boot3_api.anonymous.menu.entity.Member;
import kr.co.rland.boot3_api.auth.entity.RlandUserDetails;
import lombok.RequiredArgsConstructor;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service;

import java.util.ArrayList;
import java.util.List;
import java.util.Optional;

@lombok.extern.slf4j.Slf4j
@RequiredArgsConstructor
@Service
public class CustomUserDetailsService implements UserDetailsService {

    private final MemberRepository memberRepository;

    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
        log.info("username: {}", username);
        Optional<Member> memberOp = memberRepository.findByUsername(username);

        Member member = memberOp.orElseThrow(() -> new UsernameNotFoundException("User not found"));
        //DB가 있을경우 authorities도 DB에서 가져와야 하나,
        //현재 DB에 authorities가 없어서 임의로 ROLE_ADMIN을 부여
        List<GrantedAuthority> authorities = new ArrayList<>();
        authorities.add(new SimpleGrantedAuthority("ROLE_ADMIN"));

        return RlandUserDetails.builder()
                .id(member.getId())
                .username(member.getUsername())
                .password(member.getPwd())
                .email(member.getEmail())
                .authorities(authorities)
                .build();
    }
}