6. DVIA 앱 진단 (1) - Local Data Storage
[목차]
# Local Data Storage 설명
1. Plist
2. UserDefaults
3. Keychain
4. Core Data
5. Webkit Caching (사라진 취약점)
6. Realm
7. Couchbase Lite
8. YapDatabase
9. 요약
- Local Data Storage 항목별 확인 경로
# Local Data Storage 설명
(내부 데이터 저장소)
: iOS 애플리케이션은
임시 데이터와 영구 데이터를 저장하기 위해
로컬 시스템과 상호작용함
: 애플리케이션이 중요한 정보를 임시/영구 형식으로
안전하지 않은 상태로 저장하면(평문형태) 위험이 발생함
(ex. 자동 로그인 기능이 있어 체크하는 경우
내부 저장소에 로그인 정보가 평문 형태로
저장되는 경우가 있음)
: DVIA 앱에서는 여덟 가지 데이터 저장소에 대해 진단함
내부에 저장하기 위한 형식 종류
• XML & Plist
• SQLite files
• Keychain data
• Core data
• NSUserDefaults class
• Temporary File (data cache)
•...
data:image/s3,"s3://crabby-images/ebd75/ebd758efa30dd05d729f6a410d40ca6ca9fa550e" alt=""
하나씩 살펴본다.
1.Plist
data:image/s3,"s3://crabby-images/ee688/ee6882fc33a34021aa8d8ca124287176b5c1ada2" alt=""
# 실습
data:image/s3,"s3://crabby-images/b3c40/b3c4060cd965a448144d1dfacb09baeb2a6d0e7d" alt=""
0) Plist 항목에 들어간 후 아이디/비번 저장
data:image/s3,"s3://crabby-images/9b5f1/9b5f1e1b0226cb005554e8edb71ba06a30a4c40c" alt=""
어딘가에 저장이 되었고
확인해 봐야하는 저장소는
ㄱ. 번들 컨테이너
Applications(User)
/var/containers/Bundle/Application/진단앱
ㄴ. 데이터 컨테이너
/private/var/mobile/Containers/Data
이상 두 군데이다.
1) 번들 컨테이너 확인
Applications(User)
/var/containers/Bundle/Application/
> 수정된 날짜 가장 최신순으로 정렬 (DVIA-v2)
data:image/s3,"s3://crabby-images/e2222/e22229e1f0b4532cfe15c462f6494c1b5d38e769" alt=""
/DVIA-v2.app 접속
data:image/s3,"s3://crabby-images/29205/29205ced2e538301be44ac2845555cea0acd4107" alt=""
Info.plist 파일 더블클릭
data:image/s3,"s3://crabby-images/d76d5/d76d53939867c9e11d8356eab870e52b0851a221" alt=""
내용 확인이 가능하며
Export 또는 복사 후 노트패드로 옮긴 후
아이디/비번이 저장되어 있는지 확인
data:image/s3,"s3://crabby-images/e20aa/e20aac6b66e5b756e6d1b9b9623e611f54b5a1f1" alt=""
data:image/s3,"s3://crabby-images/ae955/ae955714e90052d81e199aba860f5ab48edc0914" alt=""
없음!
2) 데이터 컨테이너 확인
/private/var/mobile/Containers/Data/Application/
: 수정된 날짜 가장 최신순으로 정렬
data:image/s3,"s3://crabby-images/1a402/1a402e1f97a02b8157e41c96c16673752e473810" alt=""
이후 /Documents 폴더 내
userInfo.plist 를 열어보면
data:image/s3,"s3://crabby-images/7393b/7393b6102301ecd4918f346a081b577d2937d048" alt=""
중요정보가 저장되어 있음
data:image/s3,"s3://crabby-images/37a3d/37a3d35dbcbe512ba7359e915c46d37053996510" alt=""
실제 진단 시에는
모든 디렉터리를 하나씩 다 확인해야 한다.
2. UserDefaults
data:image/s3,"s3://crabby-images/13ec4/13ec492ddaf1e0d3fb9c13fd92f16a2fd511133b" alt=""
# 실습
data:image/s3,"s3://crabby-images/ee0f4/ee0f466f6349b2daac73c68f2b4f4dc210806752" alt=""
0) UserDefaults 항목에 들어간 후 데이터 저장
data:image/s3,"s3://crabby-images/48747/48747ae9b6240567125dc71f8c838fe80a095f35" alt=""
1) 파일 경로 진입
/private/var/mobile/Containers/Data/Application/UUID/Library/Preferences
data:image/s3,"s3://crabby-images/15730/15730ca68b43cfb10f9ff78148e8eabd92281640" alt=""
UserDefaults 역시 Plist 파일로 저장됨
2) 파일 확인
data:image/s3,"s3://crabby-images/7b63a/7b63a2b83050d22b6c3f389b75a19a6cb2b3a8af" alt=""
입력 데이터가 평문으로 저장된다!
3. KeyChain
data:image/s3,"s3://crabby-images/7706b/7706bcf2adcd180dc03831d434b62d03100410c0" alt=""
iOS 키체인은 암호화된 데이터베이스!
키체인은 SQLite DB로 구현되어 있음!
보안상 안전해 보이지만 복호화 도구(keychain_dumper)가
존재함
# KeyChain 덤프 실습
– DVIA-v2 앱의 [Local Data Storage > Keychain] 항목에서 테스트 가능
– /private/var/Keychains/keychain-2.db 에 키체인 데이터가 저장됨
– 키체인 항목을 확인하기 위해 keychain_dumper 도구 사용 (키체인은 암호화된 데이터베이스)
– Keychain_dumper 도구를 사용하면 탈옥된 디바이스의 키체인 내용을 덤프 가능
1) keychain_dumper 다운
https://github.com/ptoomey3/Keychain-Dumper/releases
data:image/s3,"s3://crabby-images/83919/8391956c4a17d58ebcd324b890ca85d4e2448994" alt=""
zip 파일 다운
2) 디바이스에 저장
압축 해제하지 않은 상태로
간단히 드래그&드롭으로
디바이스 내 아무곳에나 던져 넣기
data:image/s3,"s3://crabby-images/34b32/34b32cbabe36f82c49bb642d1cfc63a0b7be635c" alt=""
> 압축 해제해서 넣어도 상관 없고
ssh로 붙어서 unzip 후 실행 권한 주고
실행!
3) putty 접속 후 unzip > 권한 주고 실행
data:image/s3,"s3://crabby-images/33a84/33a8406857033077072460c14a0b1bc10d16db03" alt=""
* 특정 버전에서는 에러 나서 정상 수행 안됨
4) DVIA 키체인 데이터 입력 후 keychain 덤프 실행
data:image/s3,"s3://crabby-images/eb3d9/eb3d966b251699127e08b7910b1c42272b3d1447" alt=""
# keychain-2.db 파일을 SQLite 브라우저 설치 후 확인해보기
https://sqlitebrowser.org/dl/
data:image/s3,"s3://crabby-images/ed497/ed49744abb3d205abc7946e2fcda1bd5abb30779" alt=""
data:image/s3,"s3://crabby-images/c0f60/c0f6092284b9b2cf316d7559655fd0ef91a31a1b" alt=""
4. Core Data
data:image/s3,"s3://crabby-images/41a94/41a946b5940ef88aabe56c2ae655fd55254694ec" alt=""
MVC 모델 : 디자인 패턴
Model View Controller
data:image/s3,"s3://crabby-images/1bb95/1bb9579f51430f0d48931ce03c06c8c225e42e17" alt=""
# 실습
1) 데이터 입력
data:image/s3,"s3://crabby-images/c021c/c021c3a3481ad454e9b2860347017ddaf73d97d1" alt=""
2) Core Data 경로 접근 후 sqlite 파일 export
/private/var/mobile/Containers/Data/Application/BEE532A2-5DCF-40B3-8C8F-DE3D425103FA/Library/Application Support
data:image/s3,"s3://crabby-images/38453/3845368d0d043eec89fe9e9b2c6aa97d7221ba11" alt=""
3) sqlite 브라우저로 확인
data:image/s3,"s3://crabby-images/509ff/509ff57d7e20e005f45fd67faf4fc1e931f0d683" alt=""
코어 데이터는 테이블 이름 앞에
Z가 붙고 데이터를 확인해보면
data:image/s3,"s3://crabby-images/73f42/73f425cbb360381c8a55323b6d51252c6d8f100c" alt=""
입력 데이터 평문 노출 확인!
5. Webkit Caching
**Web View는 2020년 4월 이후로 사라진 취약점!**
data:image/s3,"s3://crabby-images/22c76/22c76304f7ff7f05b2df309c1514210703bab753" alt=""
data:image/s3,"s3://crabby-images/e91aa/e91aa99143ec702a752f286fc640203b5b31a802" alt=""
# 실습
1) 확인 경로
/priavate//var/mobile/Containers/Data/Application/AppUUID/Library/Caches
data:image/s3,"s3://crabby-images/f83bd/f83bd2e1dabb855f73442d3c4e513dfb77d5c237" alt=""
사진 설명을 입력하세요.
data:image/s3,"s3://crabby-images/e1013/e1013d835367f79febd2e0615ce2aac6270bba55" alt=""
추출 후 확인 가능!
data:image/s3,"s3://crabby-images/c5d68/c5d68fcc14d0da01a46462bb29626e0fcf33d477" alt=""
6. Realm
진단 수행 대상이
realm DB를 사용하는 경우
해당 취약점 확인!
data:image/s3,"s3://crabby-images/1359e/1359e92b6c5befcc552acf66c7c2019f719e68d1" alt=""
data:image/s3,"s3://crabby-images/4a39d/4a39d337ee043e322c42d7eb2afc3677911997ba" alt=""
# 실습
1) 데이터 입력
data:image/s3,"s3://crabby-images/aa7db/aa7dbcc882f77c09bff331a62afb5f5d420bfea5" alt=""
2) 파일 확인 후 export
/private/var/mobile/Containers/Data/Application/APPUUID/Documents/file.realm
data:image/s3,"s3://crabby-images/fc947/fc9470347ce50df3c2ec6bb54bb1da59f2670aee" alt=""
3) realm studio 설치 후 파일 확인
https://www.mongodb.com/docs/realm-legacy/kr/products/realm-studio.html
data:image/s3,"s3://crabby-images/7b7ad/7b7ad75d1ce979d9b46255ef59e378364484cad0" alt=""
데이터가 출력되지 않지만
실무에서 realm DB를 사용하는 경우
realm studio를 통해 이상없이 데이터 확인 가능
7. Couchbase Lite
data:image/s3,"s3://crabby-images/53afd/53afd11737c41f3e51b8ae009287f11610021080" alt=""
# 실습
1) 데이터 입력
data:image/s3,"s3://crabby-images/9fac6/9fac6c2797d5fed7ec35d3e0e69631b22e24200a" alt=""
2) 파일 경로 확인 후 export
/private/var/mobile/Containers/Data/Application/UUID/Library/Application Support
data:image/s3,"s3://crabby-images/fe7d3/fe7d3921e9f422acd2358e0ea640d21a7d4b7dc8" alt=""
data:image/s3,"s3://crabby-images/ac259/ac259c44fea8ee849c4892ef0181dc7cf3982177" alt=""
3) SQLite 브라우저로 확인
data:image/s3,"s3://crabby-images/9fe37/9fe37e65ccee7463ace09dec91d7611a4dec7446" alt=""
8. YapDatabase
data:image/s3,"s3://crabby-images/86c4f/86c4f81babe1fdc6eb939ff9ed627a2d65372724" alt=""
# 실습
1) 데이터 입력
data:image/s3,"s3://crabby-images/29120/29120afbb2dedca33cabab6d3eedd395530ea7cf" alt=""
2. 파일 경로 확인
/private/var/mobile/Containers/Data/Application/APPUUID/Library/Application Support
data:image/s3,"s3://crabby-images/25607/25607d096370b61a11ab5d8d04c1ae8a6bc2e443" alt=""
3. 파일 확인
data:image/s3,"s3://crabby-images/58928/58928d16e4c87e02d02235213985feafb18f68b9" alt=""
데이터가 출력되지 않지만
실무에서 yap DB를 사용하는 경우
이상없이 데이터 확인 가능
10. 요약
Local Data Storage 항목별 확인 경로
(1) plist (file.plist 파일 확인)
ㄱ. 번들 컨테이너 - Applications(User) : /var/containers/Bundle/Application/진단앱
ㄴ. 데이터 컨테이너 - /private/var/mobile/Containers/Data
(2) UserDefault (info.plist 파일 확인)
/private/var/mobile/Containers/Data/Application/UUID/Library/Preferences/파일.plist
(3) Keychain (keycahin_dumper로 확인)
/private/var/Keychains/keychain-2.db
keychain_dumper로 확인
(4) CoreData (sqlite 브라우저로 확인)
/private/var/mobile/Containers/Data/Application/APPUUID/Library/Application Support
(5) Webkit Caching (2020년 4월 이후로 사라진 취약점) (sqlite 브라우저로 확인)
/private/var/mobile/Containers/Data/Application/AppUUID/Library/Caches
(6) Realm (realm DB 사용하는 곳이라면 realm studio로 확인 가능)
/private/var/mobile/Containers/Data/Application/APPUUID/Documents/file.realm
(7) Couchbase Lite (sqlite 브라우저로 확인)
/private/var/mobile/Containers/Data/Application/APPUUID/Library/Application Support
(8) YapDatabase.sqlite (yap DB를 사용하는 곳인지 먼저 확인)
/private/var/mobile/Containers/Data/Application/APPUUID/Library/Application Support
# 대응방안
data:image/s3,"s3://crabby-images/97a57/97a57d544cd48f8a267ecaaf4c1b6b2b21a47c3e" alt=""
# 내용 및 일부 이미지 출처
: 보안프로젝트 김태영 팀장 iOS 모바일 앱 모의해킹(기초) 강의 PDF