분류 전체보기
NextJS란
ProductionNext.js Next.js는 React의 SSR(Server Side Rendering)을 쉽게 구현할 수 있게 도와주는 간단한 프레임워크입니다. React도 SSR을 고려하여 설계되었기 때문에 자체적으로도 구현이 가능하긴 하지만, 개발환경을 만들기 위해서는 생각보다 복잡합니다. 그래서 이러한 문제를 해결한 Next가 나왔고, 사용법도 꽤 간편합니다. SSR은 무엇인가요? SSR은 Server Side Rendering 약자로 처음 클라이언트가 접속했을때 브라우저에서 자바스크립트 코드를 다운로드 받아 해석 할 때까지 기다리지 않고 서버에서 보여질 HTML을 미리 준비해 클라이언트한테 응답해주는 방식을 서버 사이드 랜더링이라고 합니다. 줄여서 SSR이라고 표현합니다. SPA에서 SSR을..
프로토타이핑
- Prototype (프로토타입) 프로토타입이란 본격적인 상품화에 앞서 성능을 검증ㆍ개선하기 위해 간단히 핵심 기능만 넣어 제작한 기본 모델을 말한다. 시제품, 견본품이라고도 하며 기계, 자동차, 전자ㆍ전기, 컴퓨터, 항공ㆍ우주, 토목ㆍ건축 등 공학 산업과 패션, 교육, 의료 산업에서 주로 제작하고, 특히 IT 산업에서 활용도가 높다. - Prototyping (프로토 타이핑) 본격적으로 제품 개발ㆍ생산에 들어가면 도중에 중단하거나 취소하는 것이 쉽지 않으므로 사전에 프로토타입을 제작하고 검증 과정을 거쳐 위험 부담을 최소화한다. 이를 위해 예상 고객에게 프로토타입을 사용해보게 하고 피드백을 받아 제품 개선 시 반영하기도 하는데 이를 프로토 타이핑(prototyping)이라고 한다.
사이드프로젝트 기획 및 설계 (0)
문제 정의 : 대학 학과별 공지사항에 새로운 글이 올라왔는데, 알림이 오지 않아서 불편했고, 오더라도 문자로 오기 때문에 불편했다. 앱을 만들어서 알림이 오고, 링크를 걸어준 다음 바로 이동할 수 있게끔 하는건 어떨까? 초기 사용자 타겟 : 경영학과, 컴퓨터공학과 학생 학생수가 많아서 피드백도 원할히 이뤄질 것 같다. 새로운 기획과 함께 서버 구조를 한번 그려봤다. 기획 자체가, 새로운 글이 올라오면 모바일 클라이언트에 노티를 보내주는 단순한 기능이라서 서버리스 아키텍쳐를 구상했다.
VSCode, Babel환경에 Jest 세팅 하기
babel 환경에서 jest를 이용할 경우 jest-babel을 같이 설치한다. npm i -D jest jest-babel VSCode상에서 자동완성을 편리하기 위해서는 아래도 설치해주도록 하자. npm i -D @types/jest 아래를 통해 jest를 실행할 수 있고 npx jest 아래를 통해 스크립트를 저장할 때마다 자동으로 모든 jest 테스트 코드를 자동으로 실행시켜준다. npx jest -watchAll 리액트 컴포넌트를 테스트 하기 위해서 render를 테스트 하는 라이브러리를 설치해준다. (리액트 공식 홈펭지에서도 권장하고 있음) npm i -D @testing-library/react render를 통해 그려준 결과물은 DOM 형태로 브라우저 상에 표현되기 때문에 Matcher를 확..
안드로이드 AWS Amplify + S3에 파일 업로드 Android uploads files with AWS Amplify + S3 (3/3) S3+앱 연동
이제 S3와 앱만 연동하면 끝난다. 안드로이드 프로젝트에서 앱 레벨 그레들에 아래와 같이 추가한다. dependencies { ... implementation 'com.amplifyframework:aws-storage-s3:1.6.11' implementation 'com.amplifyframework:aws-auth-cognito:1.6.11' ... } 그리고 메니페스트에 관련 퍼미션을 추가해준다. 그리고 이전글에서 생성한 클래스에 Amplify.addPlugin(AWSCognitoAuthPlugin()) Amplify.addPlugin(AWSS3StoragePlugin()) 이 두줄을 추가해준다. (S3에 접근하기 위한 Conginito와 S3 Storage Plugin) class MyAmpl..
안드로이드 AWS Amplify + S3에 파일 업로드 Android uploads files with AWS Amplify + S3 (2/3) S3버킷 생성
이번 포스팅의 과정은 아래와 같다. 1. S3버킷 생성 2. AWS Cognito 생성 3. IAM 설정 안드로이드에서 Amplify SDK 세팅을 끝냈다면. S3 Console (s3.console.aws.amazon.com/s3/home?region=ap-northeast-2 에 들어가서 새 버킷을 만들어주자. (리전 선택은 자유~) 생성 방법은 매우 단순해서 생략 하도록 한다. AWS Cognito 설정하기 원래 AWS 를 연동하려면 AccessKey, SecretKey 로 접근해야 하지만 어디선가 보기에는 인증서가 앱에 탑재되므로 보안성이 낮아져, AWS 자체에서 제공하는 Cognito 서비스를 이용하여 인증 권한자를 추가하고, 이 정보를 앱에 탑재하는 방법을 사용한다. 아래 링크에서 Manage..
안드로이드 AWS Amplify + S3에 파일 업로드 Android uploads files with AWS Amplify + S3 (1/3) 환경 세팅
회사에서 안드로이드 클라이언트에서 S3에 파일을 업로드 기능을 구현했는데 Amplify 공식 문서가 매우 빈약하여 포스팅을 남겨본다. 크게 구현 과정은 아래와 같다. 1. 안드로이드 프로젝트에 Amplify SDK 세팅 2. S3 버킷 생성. 3. S3 버킷의 권한 설정. 4. S3 버킷과 안드로이드 프로젝트 연동. (공식문서에서 위 과정을 매끄럽게 설명하지 않고 있다;;) 아래와 같은 개발 환경이 필요하다. Node.js v10.x or later npm v5.x or later git v2.14.1 or later Android Studio version 4.0 or higher Android SDK API level 16 (Jelly Bean) or higher 터미널에서 npm을 통해 amplif..
Android S3연동 하기(0) - S3란?
AWS Amplify 스토리지 모듈은 퍼블릭, 보호 또는 프라이빗 스토리지 버킷에서 앱의 사용자 콘텐츠를 관리하기위한 간단한 메커니즘을 제공합니다. 스토리지 범주에는 다음에 대한 기본 지원이 제공됩니다. Amplify Storage 카테고리는 공개, 보호 또는 비공개 스토리지 버킷에서 앱의 사용자 콘텐츠를 관리하기위한 인터페이스를 제공합니다. 스토리지 범주에는 Amazon Simple Storage Service (S3)에 대한 기본 기본 지원이 제공됩니다. (단, Android API 레벨 16 (Android 4.1) 이상이어야만 한다.) Amplify란 ? AWS Amplify는 모바일 및 프런트 엔드 웹 개발자가 AWS에서 구동되는 안전하고 확장 가능한 풀 스택 애플리케이션을 개발하도록 지원하는 ..
TDD란
TDD (Test-Driven Development) 매우 짧은 개발 사이클을 반복하는 소프트웨어 개발 프로세스 중 하나로, 개발자느 먼저 요구 사항을 검증하는 자동화된 테스트 케이스를 작성 하고 그 후 테스트 케이스를 통과하기 위한 최소한의 코드를 생성한다. 마지막으로 작성한 코드를 표준에 맞도록 리팩토링한다. 위의 사진과 같이 TDD는 요구사항을 받은 후 세가지 절차가 반복된다. 실패 : 첫번째 절차는 실패, 실패하는 테스트 케이스를 만든다. 성공 : 두번째 절차는 성공, 우리가 작성하는 실패하는 테스트 케이스를 통과시키기 위해 코드를 작성하여 테스트를 통과시키는 것이다. 리팩토링 : 세번째 절차는 리팩토링, 우리가 구현한 코드를 더 개선시킬 방법이 생긴다면 리팩토링을 진행한다. 리팩토리을 진행하고 ..
Toast 메세지가 뜨지 않을 때.
결론 : Handler(Looper.getMainLooper()).post(Runnable { Toast.makeText( this@MainActivity, "로그인 후에 이용하실수 있습니다.", Toast.LENGTH_LONG ).show() }) 안드로이드는 반드시 UI Thread에서 화면에 대한 조작을 해야한다. 프로그래밍을 하다보면 간혹 UI Thread가 아닌 Background Thread상에서 Toast를 호출하게 되는데 위와 같이 Handler를 이용해서 명시적으로 UI Thread 상에서 호출되도록 할 수 있다.