Firebase 원격 구성 iOS 샘플 앱 둘러보기

이 가이드에서는 iOS 앱에 원격 구성을 통합하는 방법을 단계별로 알아보겠습니다. iOS용 Remote Config API에 관한 자세한 내용은 FIRRemoteConfig를 참조하세요.

요구사항

iOS 프로젝트에 Firebase 추가에서 제공하는 안내에 따라 프로젝트를 설정합니다.

클라이언트 라이브러리 설치

  1. Podfile에 다음 종속 항목을 추가합니다.

    pod 'Firebase/RemoteConfig'
    

  2. 파일을 저장하고 다음을 실행합니다.

    pod install
    

이렇게 하면 애플리케이션의 .xcworkspace 파일이 생성됩니다. 이후에 애플리케이션을 개발할 때 항상 이 파일을 사용하세요.

빠른 시작 샘플용 원격 구성 프로젝트 만들기

빠른 시작 샘플은 원격 구성을 사용하여 샘플 앱의 환영 메시지를 정의하는 예를 보여 줍니다. 빠른 시작 샘플을 실행하려면 우선 원격 구성 프로젝트를 설정해야 합니다.

Firebase 콘솔에서 새 프로젝트 만들기를 클릭하고 안내에 따라 다음 매개변수를 사용하여 Firebase 원격 구성 프로젝트를 설정합니다.

매개변수 키 기본값 참고사항
welcome_message Welcome to this sample app 다른 환영 메시지를 사용하려면 변경합니다.
welcome_message_caps false 환영 메시지가 모두 대문자로 표시되도록 하려면 true로 설정합니다.

프로젝트를 구성한 후 빠른 시작 샘플을 실행하여 Firebase 콘솔에서 정의한 환영 메시지를 확인합니다. 프로젝트에서 이 매개변수의 값을 변경하고 빠른 시작 샘플에서 원격 구성 가져오기를 탭하면 원격 구성을 통해 앱이 업데이트되는 것을 확인할 수 있습니다.

빠른 시작 샘플 빌드 및 실행

  1. 빠른 시작 샘플 코드를 다운로드하고 압축을 풉니다.

  2. 터미널 창을 열고 샘플 프로젝트 위치로 이동합니다. pod install을 실행하고 .xcworkspace 파일을 엽니다.

  3. 샘플을 빌드하고 실행합니다.

실행 방식

샘플은 우선 원격 구성 객체 인스턴스를 가져오고 캐시를 빈번하게 새로고칠 수 있도록 개발자 모드를 사용 설정합니다.

Swift

Objective-C

그런 다음 plist 파일에서 인앱 기본값을 설정합니다.

Swift

Objective-C

이제 샘플은 원격 구성 서비스에서 값을 가져오는 fetchWithExpirationDuration:completionHandler: 요청을 만들고 activateFetched를 호출하여 해당 값을 앱에 적용합니다.

Swift

Objective-C

이제 환영 메시지가 업데이트되었으므로 앱에서 업데이트된 환영 메시지를 표시할 수 있습니다.

Swift

Objective-C

stringValue, numberValue, dataValue 또는 boolValue 속성 중 하나를 사용하거나 configValueForKey: 메소드를 사용하여 원격 구성 매개변수에 액세스할 수 있습니다.

캐싱 및 제한

원격 구성은 요청에 처음으로 성공한 후 로컬에 값을 캐시합니다. 기본적으로 캐시는 12시간 후에 만료되지만, 원하는 캐시 만료 시간을 fetchWithExpirationDuration:completionHandler:에 초 단위로 전달하면 특정 요청의 캐시 만료 시간을 변경할 수 있습니다. 캐시의 값이 원하는 캐시 만료 시간보다 오래된 경우 원격 구성은 새 구성 값을 서비스에 요청합니다. 앱이 fetchWithExpirationDuration:completionHandler:를 여러 번 사용하여 새 값을 요청하면 요청에 제한이 걸려 앱에 캐시된 값이 제공됩니다.

앱 개발 중에는 개발 주기를 빠르게 반복하고 앱을 테스트하기 위해 캐시를 매우 빈번하게(1시간에 몇 번씩) 새로고침해야 합니다. 최대 10명의 개발자가 참여하는 프로젝트에서 개발 주기를 빠르게 반복하려는 경우 isDeveloperModeEnabledtrue로 설정한 FIRRemoteConfigSettings 속성을 앱에 임시로 추가하여 FIRRemoteConfig 객체의 캐싱 설정을 변경할 수 있습니다.

다음에 대한 의견 보내기...

도움이 필요하시나요? 지원 페이지를 방문하세요.