목록전체 글 (66)
nueijeel
그동안 단일 액티비티 기반의 프로젝트에서 프래그먼트 간 데이터 공유를 위해 Bundle 객체를 주로 사용해왔다.다양한 타입의 값들을 bundle에 담아 전달할 수 있는데 그 중 사용자 정의 클래스 객체를 전달하기 위해서는 직렬화하는 과정이 필요했다. 지금까지는 java의 serializable 인터페이스를 구현해 직렬화했었는데,안드로이드 환경에서 serializable은 성능적 측면에서 문제가 있을 수 있다는 점을 알게되어 더 나은 방안을 찾아보고 포스팅하게 되었다. 직렬화직렬화(Serializable)는 메모리에 있는 데이터를 디스크에 저장하거나 네트워크 통신을 통해 전달하기 위해 byte stream 형태로 변환하는 것이다. (역직렬화는 반대 개념) 그렇다면 직렬화가 필요한 경우는 언제일까?..
세모반 AOS는 3명이 담당하고 있어서 각자 맡은 부분을 따로 구현하고 별다른 코드리뷰는 진행하지 않고 있다. 그래서인지 api 호출에 필요한 레트로핏 인스턴스 생성 코드도 화면별로 다 따로 만들어져있어서많은 코드가 중복되기도 하고,개발 서버와 운영 서버 도메인을 바꿔가며 테스트할 때 baseURL에 들어가는 값을 바꿔줘야하는 번거로움도 있었다. 이런 점을 해결하기 위해 Retrofit Client 클래스를 한 파일만 두고 공통으로 사용할 수 있도록 합쳐보았다. 우선 저 과정을 공통적으로 수행하게 하기 위해레트로핏 클라이언트 생성 시 매번 다르게 입력되는 api 인터페이스 클래스 타입을 제네릭을 사용해 일반화시켜야 했다. 제네릭(Generic)이란?제네릭은 클래스나 메서드, 프로퍼티를 정의..
서론 지난번 포스팅에서안드로이드에서 서버에 PreSigned URL을 요청해 AWS S3에 이미지를 직접 업로드 하는 과정을 정리해보았다. [Android] 안드로이드에서 PreSigned URL을 이용해 AWS S3에 이미지 업로드 하기 (1)세모반 프로젝트 배포 후 백엔드 개발자분께서 이미지 처리 로직 변경을 제안해주셔서 새로 구현한 방식에 대해 포스팅하려고 한다. 기존 이미지 처리 로직 기존에는 클라이언트에서 Post api를nueijeel.tistory.com 이후 post 및 patch, put api를 백엔드쪽에서 수정해주시면서 (api request body에 파일 대신 저장된 이미지 경로를 전달)안드로이드에서도 api가 구현된 부분을 수정하여 이미지 업로드 후 서버 통신으로 데이터를 전..
세모반 프로젝트 배포 후 백엔드 개발자분께서 이미지 처리 로직 변경을 제안해주셔서 새로 구현한 방식에 대해 포스팅하려고 한다. 기존 이미지 처리 로직기존에는클라이언트에서 Post api를 호출해 서버로 데이터를 전송하면 서버는 수신한 데이터를 처리해 aws에 직접 이미지를 업로드하는 로직이었다.(데이터 전송 형태는 multipart/form-data 형식으로 전달) 하지만 이 방식은 클라이언트가 서버에 api 통신을 요청하는 횟수가 많아질수록 서버 부하가 발생한다는 단점이 있다. 아직까지 세모반은 사용자가 많지 않은 상태라 위 방식으로 처리를 해도 큰 문제가 없지만, 애초에 앱 개발을 시작할 때 지속적으로 서비스하는 앱을 만드는 게 목적이었기 때문에추후에 사용자가 많아져 서버 통신량도 증가할 경우..
📍 문제 준규가 사는 나라는 우리가 사용하는 연도와 다른 방식을 이용한다. 준규가 사는 나라에서는 수 3개를 이용해서 연도를 나타낸다. 각각의 수는 지구, 태양, 그리고 달을 나타낸다. 지구를 나타내는 수를 E, 태양을 나타내는 수를 S, 달을 나타내는 수를 M이라고 했을 때, 이 세 수는 서로 다른 범위를 가진다. (1 ≤ E ≤ 15, 1 ≤ S ≤ 28, 1 ≤ M ≤ 19) 우리가 알고있는 1년은 준규가 살고있는 나라에서는 1 1 1로 나타낼 수 있다. 1년이 지날 때마다, 세 수는 모두 1씩 증가한다. 만약, 어떤 수가 범위를 넘어가는 경우에는 1이 된다. 예를 들어, 15년은 15 15 15로 나타낼 수 있다. 하지만, 1년이 지나서 16년이 되면 16 16 16이 아니라 1 16 16이 된다..
세모반 앱 버전을 업데이트 하면서 기존에 사용하던 서버 도메인을 개발 서버에서 운영 서버로 옮겼는데 그 이후로 일부 기기에서 업데이트 된 버전을 다운받으면 로그인 화면에 데이터 로딩 화면이 뜨는 현상이 발생했다. 데이터 로딩 화면은 홈 화면이 실행되고 서버 통신되는 시간동안 다른 요소를 클릭해서 발생하는 에러를 방지하기 위해 넣은 화면인데 로그인 화면에서 이 화면이 계속 뜬다는 건... 자동로그인을 처리하는 과정에서 이전 설치시 로그인했던 데이터가 남아있기 때문일거라고 추측했다 우선 정확한 원인 파악을 위해 앱을 다시 실행하고 로그를 살펴보니 홈 화면에서 최초로 유저 프로필을 받아오는 통신이 수행되고 401 코드를 반환받았다 401은 액세스토큰 만료 코드이기 때문에 이 코드를 반환 받으면 토큰 갱신을 위..
이전 포스팅에서 카카오 로그인을 구현하는 방법에 대해서 알아보았다. 2023.11.15 - [Android/공부] - [Android] 카카오 로그인 구현하기 (+ api key 숨기는 방법) [Android] 카카오 로그인 구현하기 (+ api key 숨기는 방법) 1. 안드로이드 developer 페이지 설정 https://developers.kakao.com/console/app 카카오 developers 페이지에서 로그인 후 '내 애플리케이션' 메뉴로 들어간다. 애플리케이션 추가하기 클릭 카카오 로그인을 사용 nueijeel.tistory.com 카카오톡이 앱에 깔려져 있으면 카카오톡으로, 깔려있지 않으면 카카오 계정으로 로그인되도록 콜백이 호출되도록 코드가 구성되어 있다. 그런데 실제로 테스트를..