분류 전체보기
-
SQLite VACUUM 명령어를 통하여 안전하게 DB 백업Java-Kotlin/Android 2026. 3. 4. 23:07
Android POS/KIOSK를 개발하고 실제 운영하다보니 개발에서는 고려하지 못한 문제들이 한번씩 터지고, 그럴 때마다 데이터를 살리기 위한 DB 백업이 필요하다고 느꼈습니다. DB 백업이 있으면 어떤 시점이후 데이터는 날아갈 수 있어도, 그 시점 이전의 데이터는 모두 확정적으로 살릴 수 있기 때문입니다. DB 백업이 없을 때의 데이터 복원:모든 LOG를 수집LOG를 기반으로 모든 데이터를 수작업으로 복원 DB 백업이 있을 때의 데이터 복원:DB 직전 백업 시점까지의 데이터는 DB 백업을 복원나머지 DB 백업 시점 이후의 데이터는 LOG를 이용하여 복원 문제가 터졌을 때 LOG를 모두 수집하여 수작업으로 복원하는데에는 엄청난 시간도 걸리고, 중간중간 복원하는 사람이 빼먹거나 하면 데이터가 없어진다..
-
-
Android WebView에서 이어폰 연결 상태 감지하기 (JS Bridge)Java-Kotlin/Android 2026. 2. 19. 13:12
1. Android WebView에서 직접 이어폰 연결 상태를 감지할 수 없나요?예. 안드로이드의 WebView에서 직접 안드로이드 기기에 오디오 기기를 꽂았다는 상태를 알 수 없습니다. 웹 표준(HTML5)만으로는 하드웨어 단의 연결 상태를 직접 알 수 없음.특히 일반 이어폰(3.5mm)과 달리 USB-C 타입 오디오 장치는 시스템에서 TYPE_USB_HEADSET으로 별도 관리됨.일반 이어폰을 꽂는 동작은 ACTION_HEADSET_PLUG으로 관리됨.이를 해결하기 위해 Android 네이티브 코드에서 감지하고 안드로이드 WebView(JS)로 브릿지를 통해 신호를 주는 전략이 필요함. 2. 구현저는 해당 기능을 구현 할 때 BroadcastReceiver와 AudioDeviceCallback 둘중 ..
-
Android 14(API 34)에서 USB Serial 장치 연결 시 권한에 의한 Crash 트러블슈팅Java-Kotlin/Android 2026. 2. 11. 23:29
2025.12.03 - [Java-Kotlin/Android] - Android에서 USB Serial 장치 연결 시 USB 권한 문제 해결기 Android에서 USB Serial 장치 연결 시 USB 권한 문제 해결기최근 안드로이드 프로젝트에서 POS장비에 USB Serial 포트 통신 기능을 구현하는 중에 예상치 못한 권한 문제를 마주쳤습니다.저는 이미 AndroidManifest.xml에 USB 관련 Permission을 다 줘놨는데도 권한 문parkstate.tistory.com 저는 이전에 Android에서 USB Serial 장치를 연결 한적이 있습니다. 해당 코드를 이용하여 RFID Reader를 잘 사용 하고 있었습니다. 그러나 키오스크 타겟 장비가 기존보다 좀 더 높은 Android 버..
-
[Ktorm] MSSQL "String or binary data would be truncated" 트러블 슈팅 (varchar vs text)Java-Kotlin 2026. 1. 21. 10:22
1. 문제 상황Kotlin 기반의 ORM인 Ktorm을 사용하여 MSSQL 데이터베이스 마이그레이션 기능을 구현하고 있었습니다. 마이그레이션이 수행될 때마다 실행된 SQL 스크립트 전문(DDL)을 이력 테이블(ddl_dsl_migration_schema)에 저장하는 로직이 있는데, 길이가 긴 CREATE TABLE 스크립트를 저장하는 순간 아래와 같은 에러가 발생하며 프로세스가 중단되었습니다.2. 에러 로그 com.microsoft.sqlserver.jdbc.SQLServerException: String or binary data would be truncated in table 'CROSS_POS_DB.dbo.ddl_dsl_migration_schema', column 'script'. Truncat..
-
Git Tag를 활용한 시멘틱 버전 관리Git 2026. 1. 15. 00:00
회사에서 개발 중인 프로젝트가 이제 실 운영에 들어가면서 버전 관리가 중요하게 되었다.그래서 Git Tag를 이용하여 버전 관리를 진행하기로 했다 버전은 시멘틱 버저닝으로 매기기로 했다. 시멘틱 버전은 앞에서부터 Major.minor.patch(1.1.1) 형식으로 이루어져 있다. 해당 시멘틱 버전을 이용하여, 패치와 마이너, 메이저 업데이트를 구분할 수 있다. 나무위키 피셜:더보기메이저 버전: 하위 호환성을 보장하지 않는 API 변경사항(breaking change)를 하나라도 포함한 버전에 해당한다. 가령 기존 API를 삭제하거나, 완전히 새로운 API로 통합하는 경우 등. 이러한 경우, 메이저 버전을 올려야 한다. 유일한 예외로, 메이저 버전이 0인 동안은 어떤 불안정한 API 변경사항이 발생하더..
-
Android DataStore 를 사용하여 파일에 간단한 정보 저장하기Java-Kotlin/Android 2026. 1. 14. 23:45
회사에서 제작하는 POS 프로그램의 정보(회사, 매장, 기기 번호)를 저장해 주어야 해서 Android에서 지원하는 두 개의 라이브러리를 비교해 보았다. SharedPreferences동기적으로 작동Atomic Read/Write 보장 안됨Key-Value 저장 지원파싱 에러 발생 시 RuntimeException Throw코드가 간단하여 러닝커브가 낮음DataStore(Jetpack)비동기적으로 작동Atomic Read/Write 보장 됨Key-Value, ProtoBuf(타입을 정의 및 직렬화 가능) 저장 지원오류시 IOException로 에러를 Throw코드가 SharedPreferences보다 복잡하여 러닝커브가 상대적으로 높음Kotlin Coroutine, Flow을 사용하도록 설계됨 고민해 본..
-
SCP-380CII 영수증 프린터 안드로이드 SDK 연동기Java-Kotlin/Android 2025. 12. 31. 15:45
기존에 Sewoo 영수증 프린터와 Epson 영수증 프린터를 안드로이드 POS/KIOSK 앱에서 사용할 수 있도록 연동시켜 놓았었습니다. 하지만 최근 영업팀이 SCP-380CII 프린터가 더 기기 값이 싸서 해당 프린터도 사용하고 싶다는 의견을 주셔서 해당 프린터도 자사 안드로이드 POS/KIOSK 앱에서 사용할 수 있도록 연동개발을 진행하였습니다. 먼저 해당 기기의 안드로이드 개발 예시 프로젝트를 훑어보았습니다. 해당 프로젝트에는 Sewoo에서 제공하는 Sewoo 영수증 프린터 안드로이드 연동 모듈을 사용하여 안드로이드 상에서 SCP-380CII 프린터를 제어하고있었습니다.한 줄에 들어가는 최대 문자 수인 CPL만 다르지 나머지는 Sewoo의 영수증 프린터의 Android SDK 모듈을 사용하는 기..