![[MySQL] UUID의 개념과 성능 개선 결과](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FdF248G%2Fbtr0riG1Sma%2FY15D4kJdkViBmoR6Vk0aR1%2Fimg.png)
목표MySQL에서 UUID를 최대한 효율적으로 사용해 보기 위한 노력 과정을 기술합니다. 개요관계형 DB에서 데이터(튜플)을 식별하기 위해 PK(Primary Key, 기본키)를 사용합니다.하지만, 클라이언트와 서버 사이에서 데이터를 확인하기 위해 PK를 주고받는 것은 보안적인 측면에서 위험합니다.만약 다음과 같은 URL이 있다면 어떨까요?http://www.domain.com/user/info?userid=1파라미터로 들어가는 userid의 값만 바꿔도, 다른 사람의 정보를 확인할 수 있는 것을 예측할 수 있습니다.이처럼 예측가능한 모델이 되어 SQL Injection의 위험성이 존재하기 때문에, PK값을 그대로 넘겨주는 것은 바람직하지 않습니다.따라서, 고유값을 갖는 특정 값으로 데이터를 식별할 필요..
![[JAVA] 정규표현식으로 문제 해결하기](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FysBQI%2FbtrXBXSQzjA%2FpsmiglKB5QZEPpdp7K7F9k%2Fimg.png)
목표 정규 표현식으로 문제 해결하기: 블로그 테마 변경 중 발생한 대참사 문제 발생 개요 인턴을 진행하면서 한동안 블로그에 소홀했습니다. 쌓여있던 소재들을 다듬어 블로그에 작성하려고 합니다. 그간 수많은 블로그를 보면서 많은 것들을 느꼈습니다. 그 중 하나는, 블로그는 다른 사람이 이해하기 좋게 작성해야 한다는겁니다. 내용도 내용이지만 디자인도 중요한 요소 중 하나입니다. 조잡하게 꾸며놓은 것보다 많은 사람들이 사용하는 테마가 훨씬 보기 편했고, 확실히 다크 테마가 눈이 편하다는 느낌을 받았습니다. 개인적으로 VELOG가 읽기 편하더라구요. 마크다운으로 작성된 문서는 읽기도 편하고 필요한 정보가 어디 있을지 예상이가는 것도 좋았던 것 같습니다. 티스토리 스킨을 찾아보던 중, VELOG와 유사한 정상우님의..
![[Spring] 전역 예외 처리를 위한 @ControllerAdvice와 @RestControllerAdvice](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FwWP2P%2FbtrGzZGbdU1%2FPEunKhDXcn10rAW8dqPu1k%2Fimg.png)
목표 전역 예외처리를 위한 @ControllerAdvice와 @RestControllerAdvice에 대해서 알아보겠습니다. 개요 진행하던 프로젝트에서 리팩토링이 시급한 부분은 전체적인 구조였습니다. 복잡하고 가독성 떨어지는 코드이기 때문입니다. 이러한 구조로 만들어지는데 많은 원인이 있지만, 단연 try-catch 문이 일등 공신이라고 생각합니다. 가독성이 떨어지는 것부터, try문 안에 있는 것은 지역변수로 처리되는 점, 반환형에 맞게 return을 try-catch문 안팎으로 처리해야된다는 점 등 자연스럽게 프로젝트의 구조를 일그러뜨렸습니다. 물론, try-catch문이 나쁘다는 것은 아니지만, 발생하는 예외를 체계적으로 관리할 필요가 있었습니다. Spring은 다양한 예외 처리 방법이 있지만, 그..
![[Python] 리스트, 딕셔너리, 튜플, 집합](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FbDK4BL%2FbtrF2Ma0TCH%2Fo8Tt35cjhEHv2eR6RWBzI0%2Fimg.png)
*가독성이 다소 떨어지는 점 양해 부탁드립니다. 리스트(list) 👨🎓학생의 학점을 관리하는 프로그램을 작성해보자. #학생A의 학점 A_network = "A+" A_algorithm = "A" A_OS = "B" #학생B의 학점 B_network = "A" B_algorithm = "C" B_OS = "D" 위와 같이 변수에 원하는 값을 저장할 수 있다. 만약, 학생의 수가 매우 많아지면 어떻게 될까? → 보기도 안좋고, 유지보수하는데 최악이다. 따라서, 위와 같은 정보를 리스트를 통해 한 번에 정리할 수 있다. A_grade = ["A+", "A", "B"] B_grade = ["A", "C", "D"] 예제처럼, ‘[ ]’를 사용해서 리스트라는 자료구조로 나타낼 수 있다. 리스트는 조건문, 반복문..
![[Spring] API 문서 자동화를 위한 Swagger 3.0.0 적용](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FdbDKA0%2FbtrFY76KQlg%2FDtlS0SpquDoLeeqRIQpl30%2Fimg.png)
목표 Swagger에 대해 알아보고, JWT Security가 적용된 Springfox 3.0을 적용해보겠습니다. 목차 개요 Swagger란? 정리 개요 팀 프로젝트를 진행하면서 가장 고된 사항은 바로 API 정보를 프론트와 공유하는 것이었습니다. 노션에 직접 URL, 파라미터, 결과 등을 적어줬습니다. 프로그램이 커지니까 실수도 잦아지고, 찾기도 힘들었습니다. 이에 대한 해결책인 Swagger에 대해 알아보고, 적용을 해보도록 하겠습니다. Swagger란? Swagger는 OAS(Open Api Specification)를 위한 오픈소스 프레임워크입니다. 즉, API의 문서를 자동으로 정리해주는 것 입니다. 해당 Swagger를 협업하는 개발자에게 전달하면 Path, Request, Response, ..
![[Python] Python 기초 지식과 문자열, 입력과 출력](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FAaK5F%2FbtrFvVD9o0s%2FIYCzQKE38fOHqAc2oYyAl0%2Fimg.png)
주제 1. 키워드 2. 자료형(Data type) 3. 문자열 4. 입력과 출력 1. 키워드 특별한 의미가 부여된 단어로, 파이썬이 먼저 쓰겠다고 예약한 것이다. 키워드 목록은 다음과 같다. False/True/None/and/as/assert/break/class/continue/def/del/elif/else/except/finally/for/from/global/if/import/in/is/lambda/nonlocal/not/or/pass/raise/return/try/while/with/yeild 다음과 같은 코드를 통해 키워드를 확인할 수 있다. import keyword print(keyword.kwlist) 식별자 파이썬에서 이름을 붙일 때 사용하는 단어로, 변수나 함수의 이름으로 사용되는 ..
![[Windows API] Win32 API에서 비트맵 출력하기](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2F2qlII%2Fbtrz2qxWYNM%2FIkhhES5vDA2sh3LMCZXDmK%2Fimg.png)
목표 Win32 API 환경에서 비트맵을 출력해보도록 하겠습니다. 목차 클릭하면 해당 목차로 이동합니다. 1. 비트맵(Bitmap) 2. 비트맵 출력하기 정리 개요 앞선 포스팅에서 그래픽을 그리기 위한 스톡 오브젝트를 배웠습니다. 스톡 오브젝트의 대표적인 예로 펜, 브러시 등이 있었는데요. 간단한 선, 도형을 그리는 것은 어렵지 않지만, 높은 퀄리티의 도형을 기대하기는 쉽지 않습니다. 따라서, 우리는 미리 그려져 있는 그래픽을 불러오는 방법을 생각해봐야 합니다. 이번 포스팅은 미리 작성되어 있는 비트맵을 출력하는 것에 대해서 배워보도록 하겠습니다. 1. 비트맵(Bitmap) 비트맵은 아이콘, 그림, 사진 등과 같이 디지털 이미지를 어떠한 형식을 가지고 저장된 리소스를 뜻합니다. 어떠한 형식, 즉 특정 포..
![[Spring] JPA, RDS, MySQL 연동 시 연결 안됨-CommunicationsException](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FcQ1TCu%2FbtrypiOBKoa%2FOhHPlxMX38jaE3qgpkyGt1%2Fimg.png)
상황 현재, Spring으로 API 서버를 개발하는 프로젝트를 진행하고 있고, 카카오 API를 사용해 소셜 로그인을 구현하고 있습니다. 개발 환경은 IntelliJ IDE에서 Spring boot +JPA(Hibernate) + MySQL을 사용하고 있으며, 프론트와 연결하기 위해서 AWS의 EC2 인스턴스와 RDS를 띄워놓았습니다. 분명히, 어제 저녁까지만 해도 정상적으로 잘 동작하는 것을 확인하고 깃허브에 푸시까지 했습니다. 오늘 다시 서버를 동작시키니 접속이 안되는 상황이 발생했습니다. 아무것도 안했는데 에러가 발생한 것은 처음이라서 무척 당황했습니다. AWS의 EC2 인스턴스, RDS 인스턴스가 모두 사라진 경우 연결이 안되니, 인스턴스가 중지되어 있는지 확인하기 위해 AWS에 접속하였습니다. 접..