스프링 16

어노테이션 @Valid와 @Validated

신규 프로젝트를 수행하면서 @Validated 어노테이션을 접하게 되었다. if문을 사용하지 않고 간단하게 유효성 검증을 할 수 있는 좋은 기능이었고, 완벽하게 짚고 넘어가기 위해 정리글을 작성하게 되었다. @Valid 자바 표준 스펙으로, Controller 계층에서 사용이 가능하다. 주로 request body를 검증하는 데 많이 사용된다. MethodArgumentNotValidException 예외를 발생시킨다. 예제 사용자 정보에 대한 데이터가 들어올 때에 대한 검증예시를 작성해봤다. 이름, 전화번호, 이메일을 body로 전달받을 때 @Valid 어노테이션을 통한 검증이다. Controller package com.doomole.stockproject.controller; import com.d..

[SPRING] EXCEL 업로드하여 데이터 처리하기 #2

이전 글에서 엑셀 데이터에 대한 처리는 끝났다. 이후는 개발자가 원하는대로 데이터를 사용하면 된다. 방장은 Database를 update하는 작업을 수행했고 그에 대한 내용을 작성했다. [SPRING] EXCEL 업로드하여 데이터 처리하기 #1 엑셀 데이터를 파싱하여 Database를 업데이트할 수 있도록 해달라는 요청사항에 따라 개발을 수행하게 되었다. 까먹지 않기 위해 포스팅을 작성해본다. 시나리오 사이트의 장기 미사용자에 대해 many.tistory.com Service ExcelUtil getUpdateMemberList method에서 cell의 값을 가져온 ExcelUtil이다. cell의 타입을 가져와서 switch-case 문을 통해 맞는 type으로 데이터를 변환하여 반환한다. ★ cel..

[SPRING] EXCEL 업로드하여 데이터 처리하기 #1

엑셀 데이터를 파싱하여 Database를 업데이트할 수 있도록 해달라는 요청사항에 따라 개발을 수행하게 되었다. 까먹지 않기 위해 포스팅을 작성해본다. 시나리오 사이트의 장기 미사용자에 대해 문자메시지를 발송 후 발송된 시점으로 Database 업데이트 1. 웹페이지에서 파일을 등록하고 업데이트 버튼을 클릭 2. 서버에서 엑셀 파일 파싱 3. Dabase에 사용자 존재여부 확인 4. 존재한다면 database update 5. update된 사용자 수 페이지로 전달 예제로 아래와 같은 엑셀을 전달받을 경우 처리하는 방법에 대해 작성하겠다. pom.xml 필요한 라이브러리는 아래와 같다. 파일의 type을 체크하여 에러를 발생시키기 위해 apache tika 라이브러리를 추가했다. org.apache.po..

[백준] 10814번:나이순 정렬 - JAVA

문제 온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오. 입력 첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000) 둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다. 나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다. 출력 첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다. 풀이..

백준 2023.08.17

[DI] @Autowird vs @RequiredArgsConstructor

의존성 주입에는 생성자 주입, Setter 주입, 필드 주입이 있다. 방장은 필드 주입을 통해 프로젝트를 수행했었고, @Autowired 어노테이션을 사용했었다. 이직을 하면서 새 프로젝트를 수행하게 되었는데 이 때 @RequiredArgsConstructor 어노테이션을 처음 접하게 되었다. 결론부터 말하면 스프링에서는 생성자 주입을 권고하기 때문에 방장은 앞으로 @RequiredArgsConstructor를 사용할 예정이다. :D 따라서 이에 대해 정리해보려고 한다. @Autowired 의존 객체의 타입에 해당하는 bean을 찾아주는 역할을 한다. bean으로 등록되어 있지 않은 객체를 의존성 주입할 경우 에러가 발생한다. (Could not autowire. No beans of 'TestServi..

Google SpreadSheet API와 JAVA 연동하기 #2

https://many.tistory.com/11에서 google에 대한 설정을 마쳤다. 이번 글에서는 java에서 코드 작성 후 api 연동까지 수행해보겠다. 방장은 maven spring boot 프로젝트로 라이브러리를 추가하여 개발을 수행하였다. 1. pom.xml 필요한 라이브러리들을 추가했다. com.google.api-client google-api-client 1.25.0 com.google.oauth-client google-oauth-client 1.34.1 com.google.apis google-api-services-sheets v4-rev612-1.25.0 com.google.oauth-client google-oauth-client-java6 1.21.0 com.google.oa..