본문 바로가기
728x90
반응형

분류 전체보기182

[SpringBoot] Jackson JsonAlias 설정 및 x-www-form-urlencoded 문제 해결 JsonAlias를 사용하기위해 pom.xml에 Jackson lib를 추가합니다. org.springframework.boot spring-boot-starter-web com.fasterxml.jackson.core jackson-databind com.fasterxml.jackson.core jackson-annotations 2.9.9 com.fasterxml.jackson.core jackson-databind 2.9.9 com.fasterxml.jackson.core jackson-core 2.9.9 @JsonAlias 사용법 @Data public class UserVO { @JsonAlias(value = {"name", "userNm", "userName"} private String n.. 2020. 10. 31.
[java] StringBuffer getChars (Chars to String) https://www.tutorialspoint.com/java/lang/stringbuffer_getchars.htm Java.lang.StringBuffer.getChars() Method - Tutorialspoint Java.lang.StringBuffer.getChars() Method Description The java.lang.StringBuffer.getChars() method copy the characters from this sequence into the destination character array dst. The first character to be copied is at index srcBegin. The last character to www.tutorialspoin.. 2020. 10. 31.
[spring] @ResponseBody Annotation vs ResponseEntity @ResponseBody annotation을 사용하면 스프링이 반환 객체를 http response body로 변환합니다. ResponseEntity는 @ResponseBody annotation과 유사하게 작동합니다. 그러나 ResponseEntity 객체를 생성할 때 response header를 http response에 추가할 수도 있습니다. responseEntity를 반환 객체로 사용하는 경우 @ResponseBody annotation을 사용할 필요가 없습니다. 예제) @ResponseBody annotation 사용 @ResponseBody @RequestMapping("/getData") public ResJsonVO getData(DataVO param) { try { return t.. 2020. 10. 31.
[spring] @Valid를 이용한 validation 체크와 custom annotation으로 validation 1. Valid annotation을 이용한 validation 체크 우선, VO 클래스의 필드에 Validation을 체크하도록 annotation을 설정합니다. 예) @NotEmpty, @Length 등 @Data @EqualsAndHashCode(callSuper = false) public class SiriVO extends PagingCommonVO { private long siriId; @NotEmpty(message = "제목을 입력해주세요.") @Length(min = 0, max = 100, message = "The maximum length of the title value is 100. ") private String title; @CodeValid(message = "사용여부를.. 2020. 10. 31.
[java] 임시 비밀번호 생성 (Random vs SecureRandom vs RandomStringUtils) java.util.Random 클래스는 난수를 생성할 때 seed값으로 시간을 이용합니다. 그래서 동일한 시간에 Random 클래스를 사용하여 난수를 사용하면 동일한 값이 리턴됩니다. 예측 가능한 난수를 사용하는 경우 공격자가 SW에서 생성되는 다음 숫자를 예상하여 시스템을 공격할 수 있습니다. 시큐어코딩 가이드 - SW 보안약점 47개 항목 중 적절하지 않은 난수 값 사용 (Use of Insufficiently Random Values)에 해당됩니다. 반면에 java.security.SecureRandom 클래스는 예측할 수 없는 seed를 이용하여 강력한 난수를 생성합니다. 임시 비밀번호 생성 getRamdomPassword(10)를 호출하면 10 글자의 임시비밀번호가 생성됩니다. import ja.. 2020. 10. 31.
[MySQL] 다중 테이블 삭제 (join + delete) Delete 쿼리문으로 다수의 테이블의 데이터를 삭제하는 방법을 알아보겠습니다. 1. 테이블 A의 데이터만 삭제 DELETE FROM a USING tableA AS a LEFT JOIN tableB AS b ON a.id = b.id WHERE b.컬럼 = '값' 2. 테이블 B의 데이터만 삭제 DELETE FROM b USING tableA AS a LEFT JOIN tableB AS b ON a.id = b.id WHERE b.컬럼 = '값' 3. 테이블 A, B의 데이터 모두 삭제 DELETE FROM a, b USING tableA AS a LEFT JOIN tableB AS b ON a.id = b.id WHERE b.컬럼 = '값' 2020. 10. 31.
[flutter] 앱에서 네트워크 연결 확인 : connectivity 앱에서 네트워크 연결을 확인 하기 위해 connectivity package를 사용합니다. 1. pubspec.yaml 파일에 패키지를 등록 dependencies: connectivity: ^0.4.9+5 pubspec.yaml에 등록 후 flutter pub get 합니다. 2. Import pacakge in Dart code import 'package:connectivity/connectivity.dart'; 예제 코드) import 'dart:io'; import 'package:connectivity/connectivity.dart'; Future checkConnectionStatus() async { var result = await (Connectivity().checkConnectiv.. 2020. 10. 16.
[springboot] sql script(schema.sql, data.sql) 실행 시 한글 깨짐 로컬에서 실행할땐 한글깨짐 문제가 없었는데, 서버에서 빌드 배포 후 실행을 해보니 db에서 값을 가져오는 글자만 한글이 깨져있었습니다. src └ main └ resource └ application.yml └ data.sql └ schema.sql 처음엔 http encoding 문제인가 하여 확인해봤는데, 이미 적용되어 있었습니다. *.jsp application.yml #springboot 1.5.x spring: http: encoding: charset: UTF-8 enabled: true force: true #springboot 2.1.x server: servlet: encoding: charset: UTF-8 다시 확인해보니 http encoding 문제가 아니라 data.sql로 ins.. 2020. 10. 14.
[springboot] REST API 적용하기 REST(Representational State Transfer) WWW과 같은 분산 하이퍼미디어 시스템을 위한 소프트웨어 아키텍처의 한 형식. 자원을 이름으로 구분하고 해당 자원의 상태를 주고받는 모든 것이 REST라고 할 수 있지만, 일반적으로 REST라고 하면 좁은 의미로 HTTP를 통해 CRUD를 실행하는 API를 뜻한다. HTTP METHOD에서 PUT과 PATCH의 차이점은 아래 포스트에서 확인하세요. [HTTP METHOD] PUT vs PATCH 차이점 HTTP 메소드 중 PUT 과 PATCH가 있다. 뭔 차이여... PUT : 자원의 전체 교체, 자원내 모든 필드 필요 (만약 전체가 아닌 일부만 전달할 경우, 전달한 필드외 모두 null or 초기값 처리되니 주의!!) PATCH : �.. 2020. 10. 14.
[springboot] MyBatis resultType이 Map일경우 key를 소문자로 만들기 보통 MyBatis에서 resultType으로 목록이나 데이터를 조회할 경우 VO(Value Object)를 많이 사용합니다. 그런데 VO 가 아닌 map을 사용할 경우 key 값이 대문자로 들어갑니다. (oracle, h2 등) VO는 보통 camelCase 이거나 언더바를 포함한 소문자 명명규칙을 사용합니다. Map의 Key를 VO처럼 소문자 명명규칙을 사용하게 설정해봅시다. 사실 전자정부프레임워크를 사용하면 EgovMap을 사용하여 camelCase로 key를 세팅하도록 되어있습니다. 그래서 전자정부프레임워크처럼 Map을 상속받는 클래스를 생성하고 put 함수를 가로채 key를 lowerCase로 치환해주는 새로운 Map 객체를 만들어보겠습니다. 전자정부 프레임워크가 사용하고 있는 방법이기 때문에 .. 2020. 10. 14.
728x90
반응형