Adobe Campaign Standard 支援的行動使用案例

在此頁面中,您會找到中支援的所有行動使用案例清單。 Adobe Campaign Standard 使用 Adobe Experience Platform SDKs. 請注意,支援這些使用案例需要安裝和設定 Adobe Experience Platform SDKs, tags in Adobe Experience Platform、和 Adobe Campaign Standard. 如需詳細資訊,請參閱此 頁面.

Adobe Campaign Standard支援下列使用案例:

若要設定這些使用案例,您需要下列擴充功能:

在Campaign Standard中註冊行動設定檔

使用iOS

在iOS中,執行下列動作 Experience Platform APIs 必填:

  • Lifecycle Start,即應用程式啟動時和應用程式處於前景時。
  • Lifecycle Pause,當應用程式於背景時。

如需詳細資訊,請參閱 iOS中的生命週期擴充功能.

以下是此使用案例與iOS搭配實施的範例:

 func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {


 ACPCore.setLogLevel(.debug)
 appId = SettingsBundle.getLaunchAppId()

 //===== START Set up Adobe SDK =====
 ACPCore.configure(withAppId: appId)

 ACPCampaign.registerExtension()
 ACPIdentity.registerExtension()
 ACPLifecycle.registerExtension()
 ACPUserProfile.registerExtension()
 ACPSignal.registerExtension()
 ACPCore.start()
 ACPCore.lifecycleStart(nil)

 return true
 }

func applicationDidEnterBackground(_ application: UIApplication) {
 ACPCore.lifecyclePause()
 }

 func applicationDidBecomeActive(_ application: UIApplication) {
 // Workaround until jira AMSDK-7411 is fixed.
 sleep(2)
 ACPCore.lifecycleStart(nil)
 }

使用Android

在Android中,下列 Experience Platform APIs 必填:

  • OnResume
  • OnPause

如需詳細資訊,請參閱 Android中的生命週期擴充功能.

以下是此使用案例與Android搭配使用的範例實作:

@Override

public void onResume() {
 super.onResume();
 MobileCore.setApplication(getApplication());
 MobileCore.lifecycleStart(null);
 handleOpenTracking();
 }

 @Override
 public void onPause() {
 super.onPause();
 MobileCore.lifecyclePause();
 }

傳送推播權杖至Adobe Campaign Standard

使用iOS

在iOS中,執行下列動作 Experience Platform SDK 為必填:

以下是此使用案例與iOS搭配使用的範例實作:

func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {

 // Register Device Token
 ACPCore.setPushIdentifier(deviceToken)

使用Android

在Android中,下列 Experience Platform SDK 為必填:

以下是此使用案例搭配Android使用的範例實作:

@Override
public void onNewToken(String token) {
    Log.d(TAG, "Refreshed token: " + token);
    MobileCore.setPushIdentifier(token);
}

使用您應用程式的自訂資料擴充行動設定檔

為了讓此使用案例發揮作用,您需要為PII回傳建立規則。 如需詳細資訊,請參閱 PII回傳.

使用iOS

在iOS中,執行下列動作 Experience Platform API 為必填:

  • collectPII
    如需詳細資訊,請參閱collectPII。

以下是此使用案例與iOS搭配實施的範例:

ACPCore.collectPii(["pushPlatform":"apns", "email":email, "firstName":firstName, "lastName":lastName])

使用Android

在Android中,下列 Experience Platform API 為必填:

  • collectPII
    如需詳細資訊,請參閱collectPII。

以下是此使用案例與Android搭配使用的範例實作:

HashMap<String, String> data = new HashMap<>();
data.put("pushPlatform", "gcm");
data.put("firstName", firstNameText);
data.put("lastName", lastNameText);
data.put("email", emailText);
MobileCore.collectPii(data);

使用您應用程式的生命週期資料豐富行動設定檔

為了讓此使用案例發揮作用,您需要為PII回傳建立規則。 如需詳細資訊,請參閱 PII回傳.

注意

Adobe Campaign不會將自訂資料或生命週期資料與行動應用程式區分開來。 這兩種型別的資料都可使用collectPii回傳規則傳送至伺服器,以回應行動應用程式中的事件。

使用iOS

在iOS中,執行下列動作 Experience Platform APIs 必填:

  • Lifecycle Start,即應用程式啟動時和應用程式處於前景時。
  • Lifecycle Pause,當應用程式於背景時。

如需詳細資訊,請參閱 iOS中的生命週期擴充功能.

以下是此使用案例與iOS搭配實施的範例:

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {


 ACPCore.setLogLevel(.debug)
 appId = SettingsBundle.getLaunchAppId()

 //===== START Set up Adobe SDK =====
 ACPCore.configure(withAppId: appId)

 ACPCampaign.registerExtension()
 ACPIdentity.registerExtension()
 ACPLifecycle.registerExtension()
 ACPUserProfile.registerExtension()
 ACPSignal.registerExtension()
 ACPCore.start()
 ACPCore.lifecycleStart(nil)

 return true
 }

func applicationDidEnterBackground(_ application: UIApplication) {
 ACPCore.lifecyclePause()
 }

 func applicationDidBecomeActive(_ application: UIApplication) {
 // Workaround until jira AMSDK-7411 is fixed.
 sleep(2)
 ACPCore.lifecycleStart(nil)
 }

使用Android

在Android中,下列 Experience Platform APIs 必填:

  • OnResume
  • OnPause

如需詳細資訊,請參閱 Android中的生命週期擴充功能.

以下是此使用案例與Android搭配使用的範例實作:

@Override

public void onResume() {
 super.onResume();
 MobileCore.setApplication(getApplication());
 MobileCore.lifecycleStart(null);
 handleOpenTracking();
 }

 @Override
 public void onPause() {
 super.onPause();
 MobileCore.lifecyclePause();
 }

追蹤使用者與推播通知的互動

您需要建立推播通知追蹤回傳的規則。 如需詳細資訊,請參閱 推播通知追蹤回傳.

使用iOS

在iOS中,執行下列動作 Experience Platform SDK 為必填:

以下是此使用案例與iOS搭配實施的範例:

let deliveryId = userInfo["_dId"] as? String
let broadlogId = userInfo["_mId"] as? String
if (deliveryId != nil && broadlogId != nil) {
    ACPCore.trackAction("tracking", data: ["deliveryId": deliveryId!, "broadlogId": broadlogId!, "action":"2"])
}

使用Android

在Android中,下列 Experience Platform SDK 為必填:

以下是此使用案例與Android搭配使用的範例實作:

contextData.put("deliveryId", deliveryId);
contextData.put("broadlogId", messageId);
contextData.put("action", "2");
MobileCore.trackAction("tracking", contextData);

在您的應用程式中實作自訂事件以觸發應用程式內訊息

使用iOS

在iOS中,執行下列動作 Experience Platform SDK 為必填:

以下是此使用案例與iOS搭配實施的範例:

ACPCore.trackAction(mobileEventName, data: [:] )

使用Android

在Android中,下列 Experience Platform SDK 為必填:

以下是此使用案例與Android搭配使用的範例實作:

MobileCore.trackAction(mobileEventText, new HashMap<String,String>());

設定連結欄位以進行其他驗證

使用iOS

若要根據iOS中的應用程式內訊息設定設定設定檔範本其他驗證的連結欄位,請執行下列動作 Experience Platform SDK 為必填:

以下是此使用案例與iOS的實施範例。

若要設定連結欄位:

var linkageFields = [String: String]()
linkageFields["cusEmail"] = "john.doe@email.com"
ACPCampaign.setLinkageFields(linkageFields)

若要重設連結欄位:

ACPCampaign.resetLinkageFields(linkageFields)

使用Android

若要針對以Android應用程式內訊息為基礎之設定檔範本設定連結欄位以進行其他驗證,則需要下列Experience PlatformSDK:

以下是此使用案例在Android中的實施範例。

若要設定連結欄位:

HashMap<String, String> linkageFields = new HashMap<String, String>();
linkageFields.put("cusEmail", "john.doe@email.com");
Campaign.setLinkageFields(linkageFields);

若要重設連結欄位:

Campaign.resetLinkageFields()

本頁內容