error code 를 정의하고 적용했다. enum class ErrorCode(val code: Long, val message: String, val statusCode: HttpStatusCode) { ... // MEMBER //MEMBER_ID_NOT_FOUND(3001, "id에 해당하는 MEMBER 를 찾을 수 없습니다.", HttpStatus.NOT_FOUND), MEMBER_EMAIL_NOT_FOUND(3002, "이메일이 존재하지 않습니다.", HttpStatus.NOT_FOUND), MEMBER_EMAIL_DUPLICATE(3003, "이미 사용중인 이메일입니다.", HttpStatus.CONFLICT), MEMBER_PASSWORD_MISMATCH(3004, "비밀번호가 일치하지 않..
전체 글
🔥스프링에서 구글 이메일 메일 발송하기 의존성 implementation("org.springframework.boot:spring-boot-starter-mail:3.0.5") application.yml spring: mail: host: smtp.gmail.com port: 587 username: password: properties: mail: smtp: auth: true starttls: 환경변수로 메일과 비밀번호 설정 메일 설정 (안해줘도됨) 더보기 @Configuration @PropertySource("classpath:application.yml") class EmailConfig { @Value("\${spring.mail.host}") private val host: String? ..
배열에서 세 요소의 합이 0 이 되는 경우의 수를 찾는다. 내 풀이 class Solution { fun solution(number: IntArray): Int { var answer: Int = 0 if(number.size == 3 && number.sum() == 0) { return 1 } else if (number.size == 3 && number.sum() !=0) { return 0 } for(i in 0..number.size-3) { for(j in i+1 .. number.size-2) { for(k in j+1 .. number.size-1) { if(number[i]+number[j]+number[k] == 0) { answer += 1 } } } } return answer ..
Error Code http 상태 코드 이외에 애플리케이션의 error 를 별도 정의할 필요성이 있다. http 상태 코드 안에서 세부적으로 나눈다고 보면 될 것 같다. 상황에 따라 전달할 수 있어 api 문서의 가독성이 높아진다. 그렇기 때문에 단순히 따로 정의한 code 만 반환하는 것이 아니라 human-readble 한 정보를 포함하도록 한다. RF7808 에서 제시한 형태처럼 분류를 할 수도 있고 { "type": "/errors/incorrect-user-pass", "title": "Incorrect username or password.", "status": 401, "detail": "Authentication failed due to incorrect username or passwor..
실패한 풀이 class Solution { fun solution(n: Int, m: Int): IntArray { var answer = intArrayOf().toMutableList() if(m %n != 0) answer.add(1) else answer.add(n) answer.add((n*m)/answer[0]) return answer.toIntArray() } } 경우의 수를 if 문으로 나눠봤다. 실패한 풀이 2 class Solution { fun solution(n: Int, m: Int): IntArray { var answer = intArrayOf().toMutableList() if(m %n == 0) { answer.add(n) answer.add(m) } else if (n..
회원가입, 로그인 서비스 로직 만들어놓고 이메일 인증 구현하기 기본 구현 => 익명 닉네임 만들기 목표 : 익명 닉네임 생성 목적 : 익명 게시판의 게시글 작성자를 익명으로 나타내기 위해 1 UUID 메소드 이용 UUID : 고유성이 보장되는 id를 만들기 위한 표준규약 : 중복되기 어려운 값들을 길게 만들어서 단일 값을 보장함 8-4-4-4-12 UUID.randomUUID() => 무작위 생성 가능 근데 익명을 나타내기 위함인데 굳이 이렇게 길 필요가 없을 것 같다. 2 Random() 이용 문자열 랜덤 뽑기 val chars = "abcdefghijklmnopqrstuvwxyz" val random = java.util.Random() var nickname = "" for(i in 1..10) {..
정렬을 해서 인덱스가 0인 요소를 제거하면 순서가 바껴서 그대로 반환할 수 없다. 풀이 실패 요소를 제거하기 위해 array가 아닌 다른 컬렉션으로 바꾼 뒤 제거하고 다시 array로 반환해야 한단다. 다른 사람 풀이 class Solution { fun solution(arr: IntArray): IntArray { var answer = intArrayOf() var arrs = arr.toMutableList() // MutableList 로 변환 arrs.remove(arrs.minOrNull()) // minOrNull()로 최솟값 제거 answer = arrs.toIntArray() // 다시 IntArray 로 변환 if(arrs.size == 0) answer = intArrayOf(-1)..
백오피스 프로젝트 240122 ~ 240129 *presentation layer 내가 맡은 기능 회원가입 + 이메일 인증 게시글 좋아요 회원가입 api 아이디(이메일) 중복 검사 아이디, 비밀번호 => User 객체로 저장 => 인증 여부 상태 기본값 false 입력받은 아이디(이메일)로 인증코드 전송(메일전송서비스 호출) *인증코드 db 저장 ( 유저 id + 인증코드 ) 인증 코드 api 아이디(이메일), 비밀번호, 인증코드 받는데 *인증코드 유효시간 둘지? 코드 일치하면 인증 여부 상태 true 전환 로그인 api 아이디(이메일), 비밀번호 받고 사용자 인증 여부 상태조회해서 false 면 로그인 불가 이메일 비밀번호 검사 토큰 발급 => 리프레쉬 토큰도 발급 이메일 서비스 - 내 계정, 비밀번호..
투두 개인과제 인가기능이 안먹길래 왜 이러나 한참 찾았는데 @EnableMethodSecutiy 어노테이션을 안 넣었다. 생각도 못하고 필터만 계속 쳐다봤었다.🥲 MockMvc : 스프링에서 제공하는 웹 애플리케이션 테스트 : 컨트롤러의 동작을 테스트하는 데 사용. HTTP 요청을 작성하고 응답을 검증할 수 있다. AWS 배포 ? 일래스틱 빈스토크 생성 참조 생활코딩 책 보고 따라해보려는데 출간된지 얼마나 됐다고 ui나 생성과정이 책이랑 다르다 .! 그래서 블로그 뒤져보느라 또 한참이 걸렸다. 일단 일래스틱 빈스토크로 애플리케이션 생성을 하려는데 그보다 먼저 EC2 키 랑 인스턴스 프로파일을 생성해야 한다. 이 key 를 이용해서 빈스토크 애플리케이션 클라우드 인스턴스에 안전하게 로그인 할 수 있다고 하..
n을 3진법 상에서 앞뒤로 뒤집는다는게 자연수 n 을 3진법으로 바꾼 뒤 뒤집는 거겠지? 예로 나온 45의 경우 45 -> 1200 -> 0021 -> 7 3진법 변환 -> 뒤집음 -> 10진법 변환 와 하나도 모르겠다 .! n을 3으로 나눈 나머지를 n 이 0보다 작아질때까지 문자열에 차례대로 넣어서 앞뒤 반전된 3진법을 만들고 var answer: Int = 0 var x = n var y: String = "" while(x >0) { y += (x %3).toString() x /=3 } => 0021 이 문자열의 길이를 토대로 10진법으로 바꿔야하는데 reversed() 로 뒤집어서 => 1200 0번째 숫자 1은 3의 0승 * 1 1번째 숫자 2는 3의 1승 * 2 import kotlin.m..