본문 바로가기
  • Code Smell

!101

[JAVA] LocalDate, LocalTime, LocalDateTime 정리 LocalDate, LocalTime, LocalDateTime 정리 JodaTime이 Java의 기본으로 통합되며 생긴 날짜/시간 Object, Java8 부터 사용 가능하다. LocalDate : 년,월,일 정보 LocalTime : 시,분,(초),(나노초) 정보 LocalDateTime : 년,월,일,시,분,(초),(나노초) 정보 초와 나노초는 항상 생략 가능하다. 현재시간 구하기 LocalDateTime localDateTime = LocalDateTime.now(); LocalDate localDate = LocalDate.now(); LocalTime localTime = LocalTime.now(); 3종세트 toString LocalDate : yyyy-MM-dd LocalTime : HH.. 2020. 11. 13.
[JAVA] SSLHandshakeException 발생 시 대처 [JAVA] SSLHandshakeException 발생 시 대처 정말 짜증나는 에러다. 1. JDK의 SSL 인증서 넣기 public 망이 아닌 사내 망에서 외부 통신 시 필요 할 수 있다. 보통은 인트라 망이면 SSL 인증서 파일을 제공할텐데 그 인증서 파일을 JDK에 추가 할 수 있다. 설치 된 JDK 홈 아래 lib/security 에 있는 cacerts 라는 파일에 인증서를 추가한다. Windows 기본 설치 경로라면 C:\Program Files\Java 아래 구성되어 있을 것이고 (자세한 사항은 환경변수를 참조하면 된다.) Mac 기본 설치 경로라면 /Library/Java/JavaVirtualMachines 아래 있을 확률이 높다. 예를들어 Mac 기준이라면 /Library/Java/Jav.. 2020. 10. 7.
[Java] Enum 멤버 변수로 Enum 객체 찾기 Enum 멤버 변수로 Enum 객체 찾기 예를들어 결과 코드를 정의한 enum이 있다. public enum ExamEnums { SUCCESS("200", "성공"), WAITING("300", "대기 중"), FAIL("500", "실패"), ETC("999", "기타 에러"); @Getter private final String code; @Getter private final String description; ExamEnums(String code, String description) { this.code = code; this.description = description; } } 어느 REST에서 resultCode를 보내주고, 그 코드와 설명을 enum에 정의했을 때 위와 같이 작성 할 수.. 2020. 9. 29.
[Java] RSA 양방향 암호화 RSA 양방향 암호화 Github AES/SEED 암호화는 하나의 키를 가지고 암/복호화를 같이하는 대칭키(=암호화/복호화 키가 같음) 암호화 방식이라면 RSA는 암호화 키와 복호화 키가 다른 비대칭키 암호화 이다. 키를 만드는 과정 1. 두 소수 p , q를 준비한다. 2. p - 1, q - 1과 각각 서로소인 정수 e를 준비한다. 3. ed를 (p - 1)(q - 1)으로 나눈 나머지가 1이 되도록 하는 d를 찾는다. 4. N = pq를 계산한 후, N와 e를 공개한다. 이들이 바로 공개키이다. 한편 d는 숨겨두는데, 이 수가 바로 개인키이다. 5. 이제 p, q, (p - 1)(q - 1)는 필요 없거니와 있어 봐야 보안에 오히려 문제를 일으킬 수 있으니, 파기한다.나무위키 RSA 설명 공캐키가 .. 2020. 8. 14.
[SPRING BOOT] REST API 개발하기 5 - Spring Security REST API 개발하기 5 - Spring Security 설정 GitHub 소스 swagger-ui 페이지에 대해 접근 권한을 부여하도록 Spring Security 설정을 한다. Spring Security는 위와 같이 흐름을 타는데 나머지는 Spring Security에 기본으로 구현되어 있는 구현체를 사용하고, WebSecurity를 재정의해서 사용할 수 있는 WebSecurityConfigurerAdapter 클래스를 재정의해서 사용한다. Spring Security는 기본 기능 자체는 막강하지만 실제로 입맛대로 재정의해서 사용해야 하는경우 생각보다 손을 대야하는 부분이 많기 때문에 최대한 기본기능 내에서 사용 할 수 있도록 구현해본다. spring-security 추가를 위한 build.gr.. 2020. 8. 12.
[SPRING BOOT] REST API 개발하기 4 - JUnit 테스트 REST API 개발하기 4 - JUnit 테스트 GitHub 소스 test 패키지에서 사용할 수 있도록 spring-boot-starter-test를 implementation으로 바꿔준다. dependencies { implementation('org.projectlombok:lombok') annotationProcessor('org.projectlombok:lombok') implementation('org.springframework.boot:spring-boot-starter') implementation('org.springframework.boot:spring-boot-starter-web') // swagger2 implementa.. 2020. 8. 5.
[SPRING BOOT] REST API 개발하기 3 - Root 경로 설정 REST API 개발하기 3 - Root 경로 설정 GitHub 소스 root 경로를 입력했을 때 redirect 시킬 수 있다. 예를 들어 http://localhost:8080/ 을 입력하게 되면 아무페이지도 나오지 않던가, tomcat과 같은 WAS를 사용하게 되면 컨테이너의 루트 페이지가 보이게 되는데, 이걸 redirect 시킨다. REST API이니 swagger-ui 페이지로 보일 수 있도록 구성한다. Config 패키지가 있다면 그곳에 설정 클래스를 만들고 WebMvcConfigurer를 구현한다. WebConfig package sunghs.rest.api.config; import org.springframework.context.annotation.Configuration; impor.. 2020. 7. 28.
[SPRING BOOT] REST API 개발하기 2 - ControllerAdvice, ExceptionHandler REST API 개발하기 2 - ControllerAdvice, ExceptionHandler GitHub 소스 ControllerAdvice 및 ExceptionHandler는 클라이언트에서 우리 API로 요청이 들어왔을 때, 에러가 발생한다면 어떻게 핸들링 할지에 대한 처리. 두 어노테이션은 하는 역할은 같지만, scope에 차이가 있는데, ExceptionHandler는 Exception마다 어떻게 처리할지에 대해 메소드 레벨에 선언하는 어노테이션이다. ControllerAdvice는 모든 컨트롤러에서 Exception이 발생한다면 핸들링을 담당할 핸들링 전용 Controller에 선언하는 어노테이션이다. Exception을 처리할 UserControllerAdvice를 만든다. package su.. 2020. 7. 11.
[Java] SEED-128 양방향 암호화 SEED128 양방향 암호화 Github AES-128과 같이 대칭키를 가진 양방향 암호화이다. 암호화 및 복호화가 가능하다. 유저키가 16자리를 기반으로 암/복호화를 진행한다. 국내 KISA에서 개발되었으며 JAVA 기본 내장 알고리즘이 아니므로 SEED 블록 알고리즘 클래스 파일이 필요하다. 너무 길어서 gitHub에 올려놓았다. https://github.com/sunghs/java-utils/blob/master/src/main/java/sunghs/java/utils/cipher/support/KisaSeedCbc.java 소스 /** * SEED-128 암호화 * * @author https://sunghs.tistory.com * @see source */ public class Seed12.. 2020. 7. 9.