iOS UIActivity Sharing
Last updated
Last updated
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
iOS 6부터, 서드파티 애플리케이션은 Apple의 Inter-App Communication guide에서 설명된 것처럼 AirDrop과 같은 메커니즘을 사용하여 텍스트, URL 또는 이미지와 같은 데이터를 공유할 수 있게 되었습니다. 이 기능은 "공유" 버튼과 상호작용할 때 나타나는 시스템 전체의 _공유 활동 시트_를 통해 구현됩니다.
모든 내장 공유 옵션의 포괄적인 열거는 UIActivity.ActivityType에서 확인할 수 있습니다. 개발자는 애플리케이션에 적합하지 않다고 판단되는 특정 공유 옵션을 제외할 수 있습니다.
다음 사항에 주의를 기울여야 합니다:
공유되는 데이터의 성격.
사용자 정의 활동의 포함.
특정 활동 유형의 제외.
공유는 UIActivityViewController
의 인스턴스를 생성하여 이루어지며, 공유할 항목이 전달됩니다. 이는 다음과 같이 호출하여 달성됩니다:
개발자는 UIActivityViewController
에서 초기화된 활동 및 사용자 정의 활동과 지정된 excludedActivityTypes
를 면밀히 검토해야 합니다.
데이터를 수신할 때 다음 사항이 중요합니다:
사용자 정의 문서 유형의 선언.
앱이 열 수 있는 문서 유형의 명시.
수신된 데이터의 무결성 확인.
소스 코드에 접근할 수 없더라도 Info.plist
에서 UTExportedTypeDeclarations
, UTImportedTypeDeclarations
, CFBundleDocumentTypes
와 같은 키를 검사하여 앱이 처리하고 선언할 수 있는 문서 유형을 이해할 수 있습니다.
이 키에 대한 간결한 가이드는 Stackoverflow에서 제공되며, 시스템 전반에 걸쳐 UTI를 정의하고 가져오는 것의 중요성과 "Open With" 대화 상자에서 문서 유형을 앱과 연결하는 방법을 강조합니다.
활동 전송을 테스트하기 위해 다음을 수행할 수 있습니다:
init(activityItems:applicationActivities:)
메서드에 후킹하여 공유되는 항목과 활동을 캡처합니다.
excludedActivityTypes
속성을 가로채어 제외된 활동을 식별합니다.
항목 수신은 다음을 포함합니다:
다른 소스(예: AirDrop, 이메일)에서 앱으로 파일을 공유하여 "Open with..." 대화 상자를 표시합니다.
정적 분석 중 식별된 다른 메서드와 함께 application:openURL:options:
에 후킹하여 앱의 응답을 관찰합니다.
잘못된 형식의 파일이나 퍼징 기법을 사용하여 앱의 견고성을 평가합니다.
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)