일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- SQL 문제풀이
- python
- 파이게임
- 오라클
- LeetCode SQL
- 스프링부트 채팅서버
- 구글로그인
- pygame
- MSA
- 스프링
- kotlin 클래스
- SQL
- 프로그래머스
- 자바 스트림
- 스프링부트
- oracle
- 자바8
- javascript
- 스프링시큐리티
- Spring
- java8
- mysql
- SQL프로그래머스
- Leetcode
- js
- 자바스크립트
- spring boot
- springboot
- 코틀린 클래스
- oauth2
Archives
- Today
- Total
웅겹살의 프로그래밍 삼매경
[Spring Boot] spring security 기록용2 (회원수정 관련) 본문
728x90
회원수정
DB, 세션 둘다 수정되는 로직
기록한다
필요한 내용 주석으로 달아둠
OAUTH2 작업중으로 수정예정
1. UserApiContoller
@PutMapping("/user")
public ResponseDto<Integer> update(@RequestBody User user){
userService.update(user);
// 여기서는 트랜잭션이 종료되기 때문에 DB값은 변경이 됐음
// 하지만 세션값은 변경되지 않은 상태이기때문에 세션값 갱신이 필요함
// 세션 등록
Authentication authentication = authenticationManager.authenticate(new UsernamePasswordAuthenticationToken(user.getUsername(), user.getPassword()));
SecurityContextHolder.getContext().setAuthentication(authentication);
return new ResponseDto<Integer>(HttpStatus.OK.value(), 1);
}
2. UserService
@Transactional
public void update(User user){
// 수정시에는 영속성 컨텍스트 User 오브젝트를 영속화시키고 영속화된 User 오브젝트를 수정
// SELECT를 해서 User오브젝트를 DB로부터 가져오는 이유는 영속화를 하기위함
// 영속화된 오브젝트를 변경하면 자동으로 DB에 update를 날려주기때문
User persistance = userRepository.findById(user.getId()).orElseThrow(()->{
return new IllegalArgumentException("회원 찾기 실패!!");
});
String rawPassword = user.getPassword();
String encPassword = bCryptPasswordEncoder.encode(rawPassword);
persistance.setPassword(encPassword);
persistance.setEmail(user.getEmail());
// 회원수정 함수 종료시 서비스종료 = 트랜잭션 종료 = commit 이 자동으로 실행
// 영속화된 persistance 객체의 변화가 감지되면 더티체킹이 되어 update문을 날려줌
}
3. SecurityConfig
새로 등록한
@Bean
@Override
public AuthenticationManager authenticationManagerBean() throws Exception {
return super.authenticationManagerBean();
}
이 부분이 회원수정 시 세션변경 할때 필요하다
@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Autowired
private PrincipalDetailService principalDetailService;
@Bean
public BCryptPasswordEncoder bCryptPasswordEncoder(){
return new BCryptPasswordEncoder();
}
@Bean
@Override
public AuthenticationManager authenticationManagerBean() throws Exception {
return super.authenticationManagerBean();
}
// 시큐리티가 대신 로그인해주는데 password를 가로채기 하기에
// 해당 password가 뭘로 해쉬가 되어 회원가입이 되었는지 알아야
// 같은 해쉬로 암호화하여 DB에 있는 해쉬랑 비교 가능
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.userDetailsService(principalDetailService).passwordEncoder(bCryptPasswordEncoder());
}
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.csrf().disable() // csrf 토큰 비활성화
.authorizeRequests()
.antMatchers("/","/auth/**", "/js/**", "/css/**", "/image/**", "/dummy/**")
.permitAll()
.anyRequest()
.authenticated()
.and()
.formLogin()
.loginPage("/auth/loginForm")
.loginProcessingUrl("/auth/loginProc") // 스프링 시큐리티가 해당 주소로 요청오는 로그인을 가로챈다.
.defaultSuccessUrl("/");
;
}
}
728x90
'Spring' 카테고리의 다른 글
[Spring Boot] oauth2 google 로그인 1 (3) | 2021.02.17 |
---|---|
[Spring Boot] 카카오로그인 Token값 받기까지 기록 (1) | 2021.02.15 |
[Spring Boot] spring security 기록용 (1) | 2021.02.12 |
[Spring Boot] 스프링부트 타임리프 (thymeleaf) 정리 (1) | 2021.02.05 |
[Spring] 스프링 컨트롤러 정리 (1) | 2021.02.05 |
Comments