Swagger 도입 Api Test, 설명UI 깔끔 build.gradle에 추가 implementation("io.springfox:springfox-swagger2:2.9.2") implementation("io.springfox:springfox-swagger-ui:2.9.2") SwaggerConfig @Configuration @EnableSwagger2 class SwaggerConfig { @Bean fun docket(): Docket { return Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build() } } 위와 같이 설명, U..
데이터 베이스 스키마 설계 Todo //Column data class Todo( var index: Int? = null, // 일정 index var title: String? = null, // 일정 title var description: String? = null, // 일정 설명 var schedule: LocalDateTime? = null, // 일정 시간 var createdAt: LocalDateTime? = null, // 생성 시간 var updatedAt: LocalDateTime? = null, // 업데이트 시간 ) fun Todo.convertTodo(todoDto: TodoDto): Todo { return Todo().apply { this.index = todoDto.i..
TodoApiController 투두 앱의 CRUD 처리를 담당하는 컨트롤러 작성(설계 단계) Reqeust 에는 필요한 Bodyt 설계 -> Valid 작업들어가기 때문에 핸들러도 작성해준다. @RestController @RequestMapping("/api/todo") class TodoApiController { // R @GetMapping(path = [""]) fun read(@RequestParam(required = false) index: Int?) { // 없으면 전체조회, 있으면 단건 조회, required -> 필수값 아닌지 정하기, Optional이므로 Valid할 필요 없다. } // C @PostMapping(path = [""]) fun create(@Valid @Reque..
본 프로젝트는 테스트 주도 개발(Test-driven development, TDD)로 만들어짐 Repository 작성과 함께 테스트도 함께 작성함 실제 데이터베이스는 사용X(JPA), 메모리DB사용 Config AppConfig // 스프링 부트 실행시, 해당 값들을 먼저 참조 -> Config Class @Configuration class AppConfig { /* val database = TodoDataBase()와 같은 형태로 static 걸어서 쓰지만 Spring의 패러다임은 자동으로 주입되게 만드는 것임.*/ @Bean(initMethod = "init") // Bean으로 등록, init지정, 빈이 만들어질때 어떤 메소드 참조할지 정한다 fun todoDataBase(): TodoDat..
Exception Annotation @RestController @RequestMapping("/api/exception") @Validated class ExceptionApiController { // 연습용 Api, 실무는 X @GetMapping("/hello") fun hello(): String { val list = mutableListOf() //val temp = list[0] return "hello" } @GetMapping("") fun get( @NotBlank @Size(min = 2, max = 6) @RequestParam name: String, @Min(10) @RequestParam age: Int ): String { //통과된 경우만 -> print(Validate..
가끔, 이아니라 일하다보면 외국인이랑 일할 경우가 상당히 많다. 나 같은 경우는 한국인 보다 다른 외국인하고 일하는 경우가 더 많다. 그런데 나의 못된 성품의 탓인지 몰라도, 한국보다 후진국인 필리핀, 미얀마 등등의 동남아의 사람에게는 아무리 상사라도 막 질러버리는 습관이있다. 무의식적으로 나보다 아래라고 보는 거같다. 실제로는 나보다 훨씬 대단하고 인정 받고 있는 사람임에도 불구하고.. 이러한 경우 그러한 사람들에게 나의 부정적 이미지를 심어줄 수 있기 때문에 적어도 한국에서 하는 것 or 일본인에게 하는거 절반이라도 공손하게 대하자. 원래 한국과 같은 유교 사상이 없다고 치더라도 내가 막대하고 있는 것은 그 사람들도 본능적으로 알 거라고 생각하기 때문에 .. 결과적으로 그러한 사람들에게 막대해 봤자 ..
인터넷 상에 공개된 글을 쓴다는 것, 이러한 행위 자체가 나에게는 어느정도 의 생각의 정리를 하게 해준다. 언젠가 그러한 글을 본적이 있다. "내가 만약 글쓰기를 하지않았다면 나는 진즉에 미쳐버렸을 것이다." 지금 어느정도 굉장히 공감이 된다. 나이를 먹음에 따라 서로 자신의 생각이 강해지고 타인을 수용하려는 마음이 없어질때 그러함에도 나는 나의 사상, 생각을 밖으로 표현할 필요가 있다. 이러한 출구로써 불특정 다수에게 보여지는 이러한 글을 쓰는 것 자체가 굉장한 만족감을 준다는 것을 새삼스럽게 깨닫게 된다. 따라서 앞으로는 내가 하고 싶은 말, 내 상각을 가감없이 인터넷 상에 표현하려 한다. 누군가는 읽고 누군가는 읽지 않겠지만 이제 그러한 문제는 나에게 큰 의미가 없다. 세상을 향한 출구로써 이러한 ..
일을 하다보면 상대방을 내가 원하는 방향으로 바꾸려고 나의 주장을 너무나도 강하게 말해버릴 떄가 있다. 그것이 설령 상사라고 해도... 아무리 내가 외국에 있다고해도 나의 의견을 주입시키려 하는 것을 경계하자, 개발 경력이 짧은 나로써는 무조건 책임 회피하는 것이 좋다. 책임을 회피해야 살아남는다 특히 일본에선. 중요한 결정은 항상 매니저, 상사에게 허가를 받으면서 움직이도록 하자. 그리고 말할떄 생각좀 하면서 말하자 무조건 지르지말고, 결국 불투명한 점은 질문을 통해 해소하면 되는 부분이기 때문에 너무 스스로 결론을 내지 말도록 하자. 매우 위험한 행동임에 틀림 없다.. 머리가 어지러울땐 일단 모든걸 접고 혼자 생각정리 , 뭘해서라도 머리를 리셋 시키고 처음부터 다시 천천히 시작하는게 좋다.
92년생 나는 한국나이로 30살, 이제 어느정도 어른이 되었다고 부를 수도 있는? 나이가 되었다. 주변에서는 남들보다 조금 더 성공한 친구도 보이고 그렇지 못한 친구도 보이고.. 어느정도 갈리는 시기가 아닌가 싶다. 내가 일본생활을 시작하고 한국에서 친했던 친구들에게 전화를 할 때 마다 놀라는게 있다. 한국에서는 그렇게 친하게 지내고 오랜 시간 지냈던 친구 이지만 나이가 들고 사는 환경이 달라짐에 따라 서로의 마음이 점점 멀어지는 것을 실시간으로 느끼고 있다... 해외 생활을 해서 더욱 그렇게 느끼는 지몰라도 정말 사람의 인간관계에는 유통기한이 있나.. 라는 생각을 하게 되었다. 물론 나이먹고 친구에게 감정적인 교류를 바라는 것은 어른이 되지 못한자의 어리광같이 느껴지기도 하지만 .. 점점 친구라는 존재..
import java.util.Arrays; import java.util.List; import java.util.function.IntPredicate; public class TestClass { private static final List numList = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); public static int count(IntPredicate predicate) { int count = 0; for (int num : numList) { if (predicate.test(num)) { count++; } } return count; } public static void main(String[] args) { int evenNumCoun..
문제 프로젝트에 투입되고 나서 GitLab에서 url 에 따라 gitclone을 하려 했지만 github AccessToken 을 잘못 입력하는 바람에 인증에 실패…. 그후 다시 올바른 암호를 입력해보아도.. 이렇게 Authentication failed for … 이라는 오류 메세지가 발생하게 된다. 원인 깃 랩 GitLab 의 아이디와 1회용으로 발급되는 AccessToken의 값을 틀렸기 때문에 인증에 실패 해결 git config --local --unset credential.helper git config --global --unset credential.helper git config --system --unset credential.helper : git credential cache를 c..
문제 이해 자연수 n 주어진다 n을 3진법 상에서 뒤집는다 이를 다시 10진법으로 표현 -> Return 접근 3진법으로 변환 뒤집기 3진법 -> 10진법으로 변환 풀이 class Solution { fun solution(n: Int): Int { return n.toString(3).reversed().toInt(3) } }
Exception Annotation @ControllerAdvice : Global 예외 처리 및 특정 pakage / Controller 예외 처리 @ExceptionHandler : 특정 Controller의 예외 처리 GlobalControllerAdvice //@RestControllerAdvice(basePackageClasses = [ExceptionApiController::class]) -> Target 설정 가능 //@RestControllerAdvice // RestController의 Exception이 이 컨트롤러를 통하게 됨(Global : 괄호X) class GlobalControllerAdvice { // 특정 예외를 잡겠다고 지정 @ExceptionHandler(value ..
package com.example.mvc.controller.post import com.example.mvc.model.http.UserRequest import org.springframework.web.bind.annotation.* @RestController @RequestMapping("/api") class PostApiController { //현대 방식 @PostMapping("/post-mapping") fun postMapping(): String { return "post-mapping" } //과거 방식 @RequestMapping(method = [RequestMethod.POST], path = ["request-mapping"]) // 주소 외부 노출, url 받는 형식 다..
문제 이해 Input : x, n Return x ~ x 씩 증가 n개 array 접근 리스트 만든후 n개만큼 반복 i (index)를 곱해서 배열에 넣어줌 풀이 class Solution { fun solution(x: Int, n: Int): LongArray { val answer = mutableListOf() for (i in 1..n) { answer.add(x.toLong() * i) } return answer.toLongArray() } } 다른 사람의 풀이 class Solution { fun solution(x: Int, n: Int): LongArray = LongArray(n) { x.toLong() * (it + 1) } }
REST 란 ? REST(Representational State Transfer, 자원의 상태 전달) 네트워크 아키텍쳐 원리 RESTful 이란 ? 아래의 몇가지 조건이 잘 지켜진 api가 있을때 RESTful 한 api 라고 할 수 있다. Client, Server : 클라이언트와 서버가 서로 독립적, 분리 Stateless : 요청에 대해서 클라이언트의 상태가 서버에 저장되지 않는다. 요청하는 값을 즉각 요청 ex) 햄버거 가게에서 주문할때, 치즈버거 주문 , 치즈버거 + 콜라 각각 주문, 전에 주문한걸 기억하지 않는다. 캐시 : 클라이언트는 서버의 응답을 캐시 할 수 있다. 클라이언트가 캐시를 통해서 응답을 재사용 할 수 있어야 하며, 이를 통해 서버의 부하를 낮출 수 있다. 계층화(Layered..
문제 이해 행렬의 덧셈 ( 행과 열이 같다 ) 접근 두개의 mapIndexed 함수를 활용하여 각각 더해준다음 반환시킨다 풀이 class Solution { fun solution(arr1: Array, arr2: Array): Array { var answer = arrayOf() answer = arr1.mapIndexed { indexArr, ints -> ints.mapIndexed { indexInts, i -> i + arr2[indexArr][indexInts] }.toIntArray() }.toTypedArray() return answer } }
문제 이해 x % ( x 자릿수의 합 ) == 0 -> 하샤드 Return true/false 접근 map으로 x를 배열화 시켜 요소값의 합을 구해 자리값의 합을 구한다 나눠서 0이 되는 값의 합을 구한다 -> 비교 풀이 class Solution { fun solution(x: Int): Boolean { var answer = true var sum = 0 x.toString().map { sum += (it.toInt() - '0'.toInt()) } return x % sum == 0 } } 다른 사람의 풀이 class Solution { fun solution(x: Int): Boolean { return x % x.toString().fold(0) { acc, c -> acc + c.toInt..