data:image/s3,"s3://crabby-images/9dcbe/9dcbed6f8da1d52997326b28d4ffe0597c128128" alt="notion image"
로그인 시스템 만들기
1. 기존 로그인 컨트롤러 주석 처리
data:image/s3,"s3://crabby-images/d7dcd/d7dcd8e4f087e9738f5f509cd3cd5010bddb72a4" alt="notion image"
2. Spring Boot Starter Security 라이브러리 다운
MVN Repository에서 다운
data:image/s3,"s3://crabby-images/e6f70/e6f709f90a03d8acfe8e259f488ed15b86f2a71c" alt="notion image"
data:image/s3,"s3://crabby-images/0a47f/0a47f4d9fee8db64c14fe9dcf29b12d647e48dcc" alt="notion image"
data:image/s3,"s3://crabby-images/7381f/7381f635dc49953472683547a287ea0bf8ff4d87" alt="notion image"
스프링 프레임 워크들은 버전을 안적어주는것이 좋다.
data:image/s3,"s3://crabby-images/a3744/a374441f5e624fbb5aedff3a6b67fd66b3c2725b" alt="notion image"
이렇게 수정(알아서 스프링의 버전을 잡아준다.)
data:image/s3,"s3://crabby-images/3ecf0/3ecf041bb52990770c7313dc57fe6d6c7f4ef4bb" alt="notion image"
3. 메인페이지 테스트 해보기
모든 페이지가 잠겨버림
data:image/s3,"s3://crabby-images/c8304/c83044eacd278559928e2bef9c4790701c885fbc" alt="notion image"
data:image/s3,"s3://crabby-images/a022b/a022bb94990a949adcce53bbc7c59e64a91b3969" alt="notion image"
username = user password = 2번의 해쉬코드
시큐리티 커스터마이징
1. config 패키지 생성
data:image/s3,"s3://crabby-images/089db/089dbbe695afe4c5f0264150c411d40618d5fdb1" alt="notion image"
2. SecurityConfig 파일 생성
Web.xml과 비슷한 역할을 함. → SF가 SecurityConfig 파일을 보고 일을 한다.
data:image/s3,"s3://crabby-images/35184/3518407474901ad843f4790a37c71e064ba1f415" alt="notion image"
@Configuration // 컴포넌트 스캔 public class SecurityConfig { @Bean SecurityFilterChain configure(HttpSecurity http) throws Exception { // 인증이 필요한 페이지 http.authorizeHttpRequests(a -> { a.requestMatchers("/user/updateForm", "/board/**").authenticated().anyRequest().permitAll(); }); http.formLogin(f -> { f.loginPage("/loginForm"); }); return http.build(); } }
3. 컨트롤러 인증 로직 삭제
data:image/s3,"s3://crabby-images/7163d/7163d56c39b75e104ee3be3312b322b1a268c908" alt="notion image"
4. 테스트 해보기
data:image/s3,"s3://crabby-images/1fe8b/1fe8be9bab3bda9f75f8c321a6523c05588301ee" alt="notion image"
로그인 페이지로 이동
5. 예외 주소 설정
data:image/s3,"s3://crabby-images/6896a/6896a96eea068c357fa8f45f50a6567df44aaf02" alt="notion image"
@Bean public WebSecurityCustomizer ignore(){ return w -> w.ignoring().requestMatchers("/board/*", "/static/**", "/h2-console/**"); }
시큐리티 로그인 구현하기
1. username 조회 메서드 만들기
public User findByUsername(String username) { Query query = em.createNativeQuery("select * from user_tb where username=?", User.class); query.setParameter(1, username); try { User user = (User) query.getSingleResult(); return user; }catch (Exception e){ return null; } }
2. MyLoginService 구현하기
data:image/s3,"s3://crabby-images/0736b/0736b2574405067eff182aa2313cff4ba825055b" alt="notion image"
data:image/s3,"s3://crabby-images/82625/82625c0a45395307a51169c81002c0bea3470d30" alt="notion image"
data:image/s3,"s3://crabby-images/8b8c8/8b8c8d56c0dea278a6c4e274313b8109d4a690a8" alt="notion image"
data:image/s3,"s3://crabby-images/6e28a/6e28ab1fd8f53c829aa23e412c78a66ffe575d2f" alt="notion image"
boolean은 전부 return true로 해놓기
data:image/s3,"s3://crabby-images/c1ea2/c1ea278a4532e406d0d0d9adcab025513e009d38" alt="notion image"
data:image/s3,"s3://crabby-images/4a10e/4a10eeb3dc73eafa2e96e01c2d92b664d940c1e6" alt="notion image"
패스워드를 암호화해서 넣지않아서 오류가 남;
data:image/s3,"s3://crabby-images/e8fce/e8fced44fd7482de69d6c888e70b0ca3d63b4525" alt="notion image"
3. Mustache에서 사용가능한 세션 정보 저장
data:image/s3,"s3://crabby-images/9d152/9d1526fba46617d6d6faaefadf1fe7b105f70838" alt="notion image"
Share article