리액트 네이티브 채팅방 구현하기 요즘 리액트 네이티브를 활용해서 채팅 기능을 구현하고 있다. 그 중에서도 Android와는 달리 iOS에서 키보드가 입력창을 가리는 현상 때문에 고생이 많았다. 그 문제를 해결하던 과정을 기록하였다. KeyboardAvoidingView 이 이슈에 대해 검색을 해보면 먼저 이 KeyboardAvoidingView가 가장 먼저 결과로 나올 것이다. 그래서 처음에는 이 View를 활용해서 구현했다. 하지만, 문제점이 있었다. 입력창은 키보드 위로 잘 밀려올라가지만, 채팅 내용은 그대로 있다는 점이다. 다시 원래 보고 있던 채팅을 보려면 스크롤을 다시 해야한다는 단점이 느껴져서 해결하고자 노력했다. 링크 import React from 'react'; import { Keybo..
개발/오늘 배운 지식
Chapter 10: FastAPI 프로젝트 배포하기 이 단원에서는 FastAPI 프로젝트를 배포하는 Best Practice에 대해 배운다. 먼저 환경 변수를 사용해서 configuration을 진행하고, dependency들을 pip로 잘 관리될 수 있게 한다. 그 후 세 가지 방법으로 배포를 진행해 본다. 서버리스 클라우드 플랫폼 이용해서 배포 도커 컨테이너를 이용한 배포 리눅스 서버를 이용한 배포 또 다른 주제들은 아래와 같다 환경변수를 설정하고 사용하는 방법 파이썬 종속성 관리하기 환경변수를 설정하고 사용하기 배포에 대한 방법을 배우기 전에, 먼저 우리가 구현한 앱을 신뢰할 수 있고, 빠르고, 안전하게 배포할 수 있도록 만들어야 한다. 그 과정에 있어서 핵심적인 것이 configuration 관..
Chapter 9: API를 비동기적으로 테스트하기(with pytest, HTTPX) 실전 프로젝트를 시작하기 전 마지막 단원으로 테스트에 대해서 배워보자. 유닛 테스트 작성은 고품질의 소프트웨어 제작에 필수적인 요소이다. 파이썬에서는 기본적으로 unittest라는 모듈을 제공한다. 하지만 많은 파이썬 개발자들은 더욱 가벼운 문법을 제공하기도 하고 advanced use case를 위한 강력한 툴들을 제공하기 때문에 pytest를 더 선호한다. pytest를 이용한 unit test unittest를 이용하는 경우 import unittest from chapter9.chapter9_introduction import add class TestChapter9Introduction(unittest.Tes..
Chapter 8: 양방향 통신을 위한 웹소켓 in FastAPI | “Building Data Science Applications with FastAPI”의 챕터 8을 공부하며 정리한 내용입니다. HyperText Transfer Protocol (HTTP)는 서버에 데이터를 보내고 받기에 간편하지만 강력한 기술이다. 하지만 채팅과 같은 양방향 소통이 중요한 경우 HTTP로 구현한다면 상당히 불편함이 따른다. 짧은 시간 내에 많은 요청과 응답을 만들어야 하기에, 자원 낭비가 심할 것이다. 이러한 HTTP 단점 때문에 새로운 프로토콜 웹소켓(WebSocket)이 인기를 끌고 있다. 이 프로토콜의 목표는 client와 server 사이에 communication channel을 열어서 그들이 실시간으로 ..
Chapter 7: FastAPI에서의 인증과 보안 “Building Data Science Applications with FastAPI”의 챕터 7을 공부하며 정리한 내용입니다. API에는 모든 이가 접근할 수 있는 Public API도 있지만, 인증된 사용자들만 접근 가능한 API가 대부분이다. 따라서 private token으로 접근성을 낮추거나, 적절한 인증 시스템을 구축해야 한다. 이 챕터에서는 FastAPI가 제공하는 보안과 관련된 의존성에 대해 다룬다. 또한 웹 브라우저에서 발생하는 CORS와 CSRF 공격에 대해서도 다룬다. 세부적인 내용들은 아래와 같다. Security dependencies in FastAPI Retrieving a user and generating an acces..
| "Building Data Science Applications with FastAPI"를 읽고 정리한 글입니다. Tortoise ORM 사용하기 ORM 툴을 사용하는 이유: 관계형 DB를 다룰 때, SQL 개념을 추상화하고, 오직 python의 object만 다뤄서 복잡도를 낮추고 싶기 때문이다 Tortoise ORM: Modern and asynchronous ORM Django ORM과 유사하다. 각 DB 엔진에 따른 설치법은 링크에서 확인할 수 있다. DB 모델 생성하기 Tortoise ORM의 역할은 파이썬 객체와 DB의 entity를 연결(link)하는 것이다. class PostTortoise(Model): id = fields.IntField(pk=True, generated=True)..
Chapter 6: 데이터 베이스와 비동기 ORMs “Building Data Science Applications with FastAPI”라는 책을 읽고 정리한 내용입니다. REST API를 만드는 주된 이유: 데이터를 읽고 쓰기 위함. 하지만, 아직 데이터베이스에 대해서는 책에서 다루지 않았음. ORM: Object-Relational Mapping Relational vs NoSQL 데이터베이스 데이터베이스는 체계적으로 데이터를 저장하고, 데이터의 무결성을 유지하며, query language를 통해 필요할 때 데이터를 찾을 수 있도록 해줘야 한다. Relational Database(관계형 데이터베이스): SQL query language NoSQL: Relational DB의 반대 케이스 필요에..
FastAPI 스터디한 것 정리 Building Data Science Applications with FastAPI를 읽으며. Chapter 5: 의존성 주입 의존성 주입 장점 의도가 명확하다. a clear separation of concern between the logic of the endpoint and the more generic logic 명확한 관심의 분리가 가능하다 OpenAPI 스키마가 자동으로 제작되어서 어떤 파라미터가 필요한지 명확히 보여줄 수 있다. can clearly show which parameters are expected Creating and using a function dependency dependency는 function이나 callable class로 정..