Spring
Custom Deserializer를 Json Module방식으로 등록해보자
Custom Deserializer를 Json Module방식으로 등록해보자
2024.11.24TL; DR등록기라서 사실 요약할 내용은 없다. D2 추천 방식으로 해당하는 Enum Type을 좀 더 쉽게 Deserializing하는 방식을 체크해보고 싶었다.도입 이유1. Enum Type의 사용 이유일단 개발하다보면, 100% 확률로 Enum Type을 사용할 수 밖에 없기때문에 해당하는 타입을 Enum화 해서 관리하는게 좋다. 실제로 실무에서는 DB에 저장되는 형태랑, 실제로 Json 타입으로 주는 형태랑 다를 경우가 많다. 즉, 해당하는 걸 매번 Enum의 키값으로 지정하기에 부담스러울때가 종종 있기 때문이다.일단 Enum 타입을 만들고, 해당하지 않은 타입으로 전달하게 되면 대략 이런 오류가 발생하기 마련이다.import lombok.Getter; import lombok.RequiredA..
에러에 상태에 따라서 로깅 레벨을 조절해보자
에러에 상태에 따라서 로깅 레벨을 조절해보자
2024.11.10TL; DR선호하진 않을 방식일순 있으나, 에러에 대한 익셉션이 하나로 결정되어진 경우 ControllerAdvicer의 로그레벨을 무조건 한 가지로 고정해버리면 간혹 이 에러에 대한 오류를 지정하기가 힘들어진다. 차라리 이럴때는 Exception에 로그레벨을 넣고, Sl4fj에서 제공하는 makerLoggingEventBuilder기능을 활용하면 좋다. 익셉션에 로그레벨을 프로퍼티로 넣고, 꺼내서 해당하는 어드바이저의 레벨과 상관없이 자동으로 출력하자1. 이런 상황이 만들어지게된 배경에러 로그를 Exception별로 만들게 되면, 로깅을 우리팀에서는 ControllerAdvicer에서 처리하는 방식으로 구현했었다. 근데 이렇게 하면 문제가 되는 지점이 공통분모로 묶어둔 익셉션이 자주 에러를 발생해서 가..
@AuthenticationPrincipal과 getAuthentication()에서 가져온 principal의 다른점은 있을까?
@AuthenticationPrincipal과 getAuthentication()에서 가져온 principal의 다른점은 있을까?
2024.10.27TL; DR없다 같은것이기 때문에 크게 신경쓰지 말자 타입캐스팅도 자동으로 되기때문에 굳이 서비스 로직이아니라면 Parameter화시키는게 더 편하다.왜 궁금했나?@CreatedBy 나 @LastModifiedBy를 사용하는 경우 Auditor를 구성하기위해 implements AuditorAware 과 같은 Aware를 이용하게되는데, 개발시 스프링에서 제공하는 예시를 보더라도...class SpringSecurityAuditorAware implements AuditorAware { public User getCurrentAuditor() { Authentication authentication = SecurityContextHolder.getContext().getAuthentication(..
Transactional의 Self Injection이 올바른가
Transactional의 Self Injection이 올바른가
2024.06.22TL; DR올바르지 않고, 쓰지마. Self Injection은 기본적으로 Spring이랑 Spring Boot에서 기본 논점으로 막고 있음. 왜냐하면 무한 참조에 위험성을 가지고 있고 @Lazy를 위한 방식으로 처리할 수는 있는데.. 굳이 그렇게 쓰는거 자체가 전자에 발생할 위험성을 포함하고 있음. 스프링 부트의 경우는 아예 기본으로 순환 참조시 아예 Application 켜지지 않는 이슈도 있음. 아님 허용하고 Spring boot 전체가 전부 Self Injection이 가능해져야하기 때문에 비선호기본적으로 Spring에서 권고하지 않는 사항이면, 안하는게 좋다고 생각함. 프레임워크기 때문에 굳이 벗어나는 행동을 하는건 좋지 않다고 생각함왜 이 주제가 생각났는가?팀내에서 소나큐브를 적용해보자는 이야..
Hibernate 신기능 @SoftDelete 기능
Hibernate 신기능 @SoftDelete 기능
2024.04.10Spring Boot도 벌써 3.2.X버전대가 릴리즈 되었고, 그에 따라서 자동으로 하이버네이트도 마이너 버젼 업데이트가 되었습니다. 6.4 버젼부터 해당하는 기능을 사용할 수 있습니다. 해당하는 기능을 한번 사용해보고 싶어서 테스트 해봤습니다. 일단 기본적으로 스프링 부트는 3.2.1 부터 사용 가능할 수 있으므로 참고 부탁드립니다. 기존에 사용하던 Soft Delete 방식 기존에는 Soft Delete기능을 사용하기 위해서는 개념적으로 사용해야하는 @Where절과 같은 기능을 사용하여, 삭제 컬럼에 대한 flag에 대한 조건을 엔티티 자체에 붙여서 사용해야했다. 그리고 삭제조건을 자동으로 update절로 바꿔서 처리할 수 있는 @SqlDelete문 과 같은 어노테이션이 필요했다. 즉, 개념적인 So..
@JsonInclude란?
@JsonInclude란?
2024.02.04일단 글또 5주차를 맞이하여 테크테크스러운 글을 많이 작성하고 있다. 특히 요즘에는 별다른건 아니고, Jackson에 좀 꽂혀서 요즘 Serialize 혹으 Deserialize하는 방식에 대해서 어떤식으로 작동하는 거고 해당하는 코드들이 어떤 일련의 과정 속에서 움직이는 게 궁금했었다. 일단 기본적으로 Include를 많이 사용은 하는데 어떤 상황에서 사용하는게 좋을지 취사선택해야하는 경우가 많은데, 해당하는 값을 어떤식으로 처리하는게 좋을지 궁금해졌다. 사실은 Include nonNull 동작원리를 찾다가 동작방식을 찾아내질 못해서, 다른 주제로 선회하긴했다. 찾아보니까 이렇게 딥한 내용이었나 싶어서 좀 더 구체적으로 테스트 해봐도 좋겠다싶었다 JsonInclude란? 일단 JsonInclude라는 ..
부모 - 자식 관계에 있는 DTO를 효과적으로 표현하는 JsonTypeInfo Deduction기능을 알아보자.
부모 - 자식 관계에 있는 DTO를 효과적으로 표현하는 JsonTypeInfo Deduction기능을 알아보자.
2024.01.21왜 쓰게 되었나.. 일단 회사 프로젝트가 잦은 야근으로 지난주를 훌렁 날려버린 나는 현재 눈물의 개발 글쓰기를 진행중인데, 해당하는 프로젝트 진행도중 Request는 공통정보가 있지만, 각 3rd-party 서비스 추가 응답을 활용해서 각각의 응답에 따라 다른 API를 넘겨줘야하는 상황에 봉착했다. 해당하는 프로젝트에서 중복적으로 많이 사용되는 field가 있었고.. 해당하는 필드를 각 DTO별로 중복적으로 사용하는건 좀 귀찮은 일이기도 하니.. 해당하는 형태를 부모-자식 형태를 통해 상속으로 처리를 하려했다. 상속의 경우 Json Serialize가 값으로 처리되기가 곤란한 경우가 종종 있었는데, 특히나 Spring boot에서 별다른 어노테이션이 없이 무자비하게 떨렁 응답에 대한 처리를 해봤자.. 상..
테스트 코드를 짜고는 싶은데, 테스트 실패시 빌드 실패가 걱정된다면?
테스트 코드를 짜고는 싶은데, 테스트 실패시 빌드 실패가 걱정된다면?
2023.09.02test.onlyIf { !project.hasProperty('test') } 다음처럼 작성해주면, 테스트 프로퍼티가 있는경우 혹은 해당 프로퍼티의 존재 여부를 따져서 테스트에 대한 실행을 막는다. 위에는 스크립트문으로 강제하는 방법이라면, 명령어로 강제하는 방법도 있음. gradle build -x test 하지만, 실제로 빌드 환경을 구축해두면 스크립트로 테스트가 다 돌아가므로, 굳이 아래 스크립트문 까지 사용하는 것보다는 위의 빌드 제약 조건으로 걸어 주는게 더 좋다고 생각한다. 물론 스크립트로 테스트가 돌아가는 것은 gradle build 스크립트를 반드시 돌리는 상황이 생겨서 그런거지.. 우리가 직접 스크립트문을 작성해서 돌린다면, 스크립트 명령문으로 강제 할 수는 있다 출처 https://a..
Spring boot build gradle에서 test task시 하면 좋은 것.
Spring boot build gradle에서 test task시 하면 좋은 것.
2023.09.02build.gradle 파일에서 tasks.named('test') }{ useJunitPlatform() } 이렇게 많이 쓰는데, gradle 가이드 문서에서 추천하는 방식은 다음처럼 tasks.named('test', Test) }{ useJunitPlatform() } 이래야지 useJunitPlatform이 메소드 역할을 하는것. 참고로 Spring Boot 기본 설정에서 제공하는 양식이 위의 양식으로 build.gradle이 되어있어서 그런거지 실제로 gradle 버전업을 통해서 적용 해야할 문법은 아래가 맞다 물론 없어도 동작은 하는듯한데.. 암튼 공식문서에선 그랬다. https://docs.gradle.org/current/userguide/java_testing.html#sec:java_t..
Spring 설정파일 우선순위
Spring 설정파일 우선순위
2023.04.11Application.yaml 설정 파일 실행시 우선순위 매번 까먹어서 한번 재대로 정리해봄 default 셋업 아래에 on-profile 설정되어있는데 안먹어서 왜 안먹나 했더니 application.yaml이 우선순위가 높아서 default 옵션을 무시하고 다른 옵션이 들어가버려서 안되길래 도대체 어떤식으로 해결해야하는지 확인해봤다. 이경우에는 application.yaml에 profile이 있으면 됨 혹은 아예 파일이 따로 존재한다던지 여러가지 방법이 존재하니 참고 Application.yaml은 다음과 같은 우선순위를 가지게된다. 1. [Application properties](https://docs.spring.io/spring-boot/docs/current/reference/html/fea..
Spring boot 3.0.0 SQL Basic Binder 로깅 안되는 문제 해결기
Spring boot 3.0.0 SQL Basic Binder 로깅 안되는 문제 해결기
2022.12.02스프링부트에서 SQL문을 로깅하자 JPA에서 sql문 로깅하기 위해서는 application.yml에서 로깅레벨이나 옵션 사용해서 문제해결을 한다. spring: jpa: properties: hibernate: format_sql: true use_sql_comments: true logging: level: org.hibernate.SQL: debug org.hibernate.type.descriptor.sql: trace 이러면 JPA를 통해서 만들어지는 SQL문을 확인해볼 수도 있고… SQL문에서 발생하는 ?를 통해 들어가진 값들도 확인이 가능하다. 아래는 2.7.6 Spring boot 버젼입니다. 아래는 3.0.0 Spring Boot 버젼입니다. Spring Boot 3.0.0 버젼으로 넘어..
Spring RestDocs를 통한 Swagger 페이지 구축기 - 1. 구성하기
Spring RestDocs를 통한 Swagger 페이지 구축기 - 1. 구성하기
2022.07.24테스트 코드로 API docs 관리를 할 수 있다고? Spring Rest Docs 라이브러리는 테스트 코드를 작성하면 Asciidoc 파일을 통해서 테스트 코드를 구현할 수 있다. 하지만, 불편한 점들이 눈에 밟혔다. Asciidocs 파일에 대한 이해도가 반드시 필요했으며, Rest Docs가 기본적으로 제공하는 Docs 제공 하는 페이지가 나랑 취향이 너무 안맞았다. 솔직히 보면서 이렇게 까지 써야할까라는 생각을 했었는데… 웹사이트를 뒤적뒤적 거리다 마침 RestDocs 테스트 코드를 바탕으로 Swagger 문서를 구성할 수 있는 라이브러리를 찾아, 그 기능을 사용해보기로 했다. 구축기 가장 본 바탕이 되었던 이 레포지토리를 기준으로 개발 환경 세팅 방법을 확인하자. https://github.co..