API Lawas Android

Direct deep linking

Overview

Deep linking langsung mengarahkan pengguna seluler ke aktivitas atau konten tertentu di aplikasi, saat aplikasi sudah diinstal.

Perutean dalam aplikasi ke aktivitas tertentu dalam aplikasi ini dimungkinkan karena parameter diteruskan ke aplikasi saat OS membuka aplikasi dan onAppOpenAttribution method is called. AppsFlyer's OneLink ensures that the correct value is passed along with the user's click, thus personalizing the user’s app experience.

Only the deep_link_value is required for deep linking. However, other parameters and values (such as custom attribution parameters) can also be added to the link and returned by the SDK as deep linking data.

Alur deep linking langsung berfungsi sebagai berikut:

Direct Deep Linking flow

  1. Pengguna mengklik URL pendek OneLink.
  2. Android meluncurkan aplikasi berdasarkan aktivitas yang relevan di AndroidManifest.xml.
  3. SDK AppsFlyer dipicu di aplikasi.
  4. SDK AppsFlyer mengambil data OneLink.
    • Dalam URL pendek, data diambil dari API penyelesai URL pendek di server AppsFlyer.
    • Di URL yang panjang, data diambil langsung dari URL yang panjang.
  5. AppsFlyer SDK triggers onAppOpenAttribution() with the retrieved parameters and cached attribution parameters (e.g. install_time).
  6. Asynchronously, onConversionDataSuccess() is called, holding the full cached attribution data. (You can exit this function by checking if is_first_launch is true.)
  7. onAppOpenAttribution() menggunakan peta attributionData untuk mengirimkan aktivitas lain di aplikasi dan meneruskan data yang relevan.
    • Ini menciptakan pengalaman yang dipersonalisasi bagi pengguna, yang merupakan tujuan utama OneLink.

Procedures

To implement the onAppOpenAttribution metode dan mengatur perilaku parameter, daftar periksa tindakan berikut dari prosedur harus diselesaikan.

Daftar periksa prosedur

  1. Memutuskan perilaku aplikasi dan deep_link_value (and other parameter names and values) - with the marketer
  2. Input metode perencanaan, yaitu deep_link_value (and other parameter names and values) - with the marketer
  3. Menerapkan onAppOpenAttribution() logic
  4. Menerapkan onAttributionFailure() logic

Menentukan perilaku aplikasi

Untuk menentukan perilaku aplikasi saat tautan diklik :

Dapatkan dari pemasar: Perilaku yang diharapkan dari tautan saat diklik.

Input metode perencanaan

When a OneLink is clicked and the user has the app installed on their device, the onAppOpenAttribution method is called by the AppsFlyer SDK. This is referred to as a retargeting re-engagement.

The onAppOpenAttribution metode mendapatkan variabel sebagai masukan seperti ini: Map <String, String>.
Struktur data masukan dijelaskan di sini.

Menerapkan logika onAppOpenAttribution()

The deep link opens the onAppOpenAttribution metode dalam kegiatan utama. Parameter OneLink dalam input metode digunakan untuk mengimplementasikan pengalaman pengguna tertentu saat aplikasi dibuka.

Contoh Kode:

@Override
  public void onAppOpenAttribution(Map<String, String> attributionData) {
  if (!attributionData.containsKey("is_first_launch"))
    Log.d(LOG_TAG, "onAppOpenAttribution: This is NOT deferred deep linking");
  for (String attrName : attributionData.keySet()) {
    String deepLinkAttrStr = attrName + " = " + attributionData.get(attrName);
    Log.d(LOG_TAG, "Deeplink attribute: " + deepLinkAttrStr);
  }
  Log.d(LOG_TAG, "onAppOpenAttribution: Deep linking into " + attributionData.get("deep_link_value"));
  goToFruit(attributionData.get("deep_link_value"), attributionData);
}

@Override
  public void onAttributionFailure(String errorMessage) {
  Log.d(LOG_TAG, "error onAttributionFailure : " + errorMessage);
}

private void goToFruit(String fruitName, Map<String, String> dlData) {
    String fruitClassName = fruitName.concat("Activity");
    try {
        Class fruitClass = Class.forName(this.getPackageName().concat(".").concat(fruitClassName));
        Log.d(LOG_TAG, "Looking for class " + fruitClass);
        Intent intent = new Intent(getApplicationContext(), fruitClass);
        if (dlData != null) {
            // Map is casted HashMap since it is easier to pass serializable data to an intent
            HashMap<String, String> copy = new HashMap<String, String>(dlData);
            intent.putExtra(DL_ATTRS, copy);
        }
        startActivity(intent);
    } catch (ClassNotFoundException e) {
        Log.d(LOG_TAG, "Deep linking failed looking for " + fruitName);
        e.printStackTrace();
    }
}

⇲ Tautan Github: Java

ℹ️

Catatan

onAppOpenAttribution tidak dipanggil saat aplikasi berjalan di latar belakang dan Aplikasi LaunchMode tidak standar.
Untuk memperbaikinya, hubungi setIntent(intent) metode untuk mengatur nilai maksud di dalam metode yang diganti onNewIntent jika aplikasi menggunakan non-standar LaunchMode.

import android.content.Intent;
 ...
 ...
 ...
 @Override
 protected void onNewIntent(Intent intent) 
 { 
   super.onNewIntent(intent);     
   setIntent(intent);
 }

Menerapkan logika onAttributionFailure()

The onAttributionFailure method is called whenever the call to onAppOpenAttribution fails. The function should report the error and create an expected experience for the user.

@Override
public void onAttributionFailure(String errorMessage) {
    Log.d(LOG_TAG, "error onAttributionFailure : " + errorMessage);
}

⇲ Tautan Github: Java

Deferred Deep Linking

Overview

Deferred deep linking mengarahkan pengguna baru terlebih dahulu ke toko aplikasi yang benar untuk menginstal aplikasi, dan kemudian, setelah pembukaan pertama, ke pengalaman aplikasi tertentu (misalnya halaman tertentu di aplikasi).

When the user first launches the app, the onConversionDataSuccess callback function receives both the conversion data of the new user, and OneLink data. The OneLink data makes in-app routing possible due to the deep_link_value atau lainnya yang diteruskan ke aplikasi saat OS membuka aplikasi.

Only the deep_link_value is required for deep linking. However, other parameters and values (such as custom attribution parameters) can also be added to the link and returned by the SDK as deep linking data. The AppsFlyer OneLink ensures that the correct parameters are passed along with the user's click, thus personalizing the user’s app experience.

The marketer and developer must coordinate regarding desired app behavior and deep_link_value. The marketer uses the parameters to create deep links, and the developer customizes the behavior of the app based on the value received.

Programmer bertanggung jawab untuk memastikan parameter ditangani dengan benar di aplikasi, baik untuk perutean dalam aplikasi dan mempersonalisasi data di tautan.

Alur deferred deep linking berfungsi sebagai berikut:
Deferred Deep Linking flow!

  1. Pengguna mengklik OneLink di perangkat yang tidak menginstal aplikasi.
  2. AppsFlyer mendaftarkan klik dan mengarahkan pengguna ke app store atau halaman arahan yang benar.
  3. Pengguna menginstal aplikasi dan meluncurkannya.
  4. SDK AppsFlyer diinisialisasi dan pemasangan diatribusikan di server AppsFlyer.
  5. The SDK triggers the onConversionDataSuccess method. The function receives input that includes both the deep_link_value, and the attribution data/parameters defined in the OneLink data.
  6. Parameter is_first_launch has the value true, yang menandakan alur deferred deep link.
    Pengembang menggunakan data yang didapatkan di onConversionDataSuccess berfungsi untuk menciptakan pengalaman yang dipersonalisasi bagi pengguna untuk peluncuran pertama aplikasi.

Procedures

To implement the onConversionDataSuccess method and set up the parameter behaviors, the following action checklist of procedures need to be completed.

  1. Memutuskan perilaku aplikasi pada peluncuran pertama, dan deep_link_value (and other parameter names and values) - with the marketer
  2. Input metode perencanaan, yaitu deep_link_value (and other parameter names and values) - with the marketer
  3. Menerapkan onConversionDataSuccess() logic
  4. Menerapkan onConversionDataFail() logic

Menentukan perilaku aplikasi pada peluncuran pertama

Menentukan perilaku aplikasi pada peluncuran pertama:

Dapatkan dari pemasar: Perilaku tautan yang diharapkan saat diklik dan aplikasi dibuka untuk pertama kalinya.

Input metode perencanaan

For deferred deep linking, the onConversionDataSuccess method input must be planned and the input decided in the previous section (for deep linking) is made relevant for the first time the app is launched.

The onConversionDataSuccess method gets the deep_link_value dan variabel lain sebagai input seperti ini: Map <String, Object>.

Peta menyimpan dua jenis data:

  • Data atribusi
  • Data defined by the marketer in the link (deep_link_value and other parameters and values)
    Other parameters can be either:
    • Parameter resmi AppsFlyer.
    • Parameter dan nilai khusus yang dipilih oleh pemasar dan programmer.
    • Struktur data input dijelaskan di sini .

The marketer and developers need to plan the deep_link_value (and other possible parameters and values) together based on the desired app behavior when the link is clicked.

To plan the deep_link_value, and other parameter names and values based on the expected link behavior:

  1. Beri tahu pemasar parameter dan nilai apa yang diperlukan untuk menerapkan perilaku aplikasi yang diinginkan.
  2. Decide on naming conventions for the deep_link_value and other parameters and values.
    Note:
    • Parameter kustom tidak akan muncul dalam data lengkap yang dikumpulkan di AppsFlyer.
    • Data konversi tidak akan mengembalikan parameter kustom yang disebut "nama, " dengan huruf kecil "n".

Menerapkan logika onConversionDataSuccess()

When the app is opened for the first time, the onConversionDataSuccess method is triggered in the main activity. The deep_link_value and other parameters in the method input are used to implement the specific user experience when the app is first launched.

Untuk menerapkan logika :

  1. Menerapkan logika berdasarkan parameter dan nilai yang dipilih. Lihat contoh kode berikut.
  2. Setelah selesai, kirim konfirmasi ke pemasar bahwa aplikasi berperilaku sesuai.

Kode sampel

@Override
 public void onConversionDataSuccess(Map<String, Object> conversionData) {
     for (String attrName : conversionData.keySet())
         Log.d(LOG_TAG, "Conversion attribute: " + attrName + " = " + conversionData.get(attrName));
     String status = Objects.requireNonNull(conversionData.get("af_status")).toString();
     if(status.equals("Non-organic")){
         if( Objects.requireNonNull(conversionData.get("is_first_launch")).toString().equals("true")){
             Log.d(LOG_TAG,"Conversion: First Launch");
             if (conversionData.containsKey("deep_link_value")){
                 Log.d(LOG_TAG,"Conversion: This is deferred deep linking.");
                 //  TODO SDK in future versions - match the input types
                 Map<String,String> newMap = new HashMap<>();
                 for (Map.Entry<String, Object> entry : conversionData.entrySet()) {
                         newMap.put(entry.getKey(), String.valueOf(entry.getValue()));
                 }
                 onAppOpenAttribution(newMap);
             }
         } else {
             Log.d(LOG_TAG,"Conversion: Not First Launch");
         }
     } else {
         Log.d(LOG_TAG,"Conversion: This is an organic install.");
     }
 }

⇲ Tautan Github: Java

Menerapkan logika onConversionDataFailure()

The onConversionDataFailure method is called whenever the call to onConversionDataSuccess fails. The function should report the error and create an expected experience for the user.

To implement the onConversionDataFailure metode :

@Override
public void onConversionDataFail(String errorMessage) {
    Log.d(LOG_TAG, "error getting conversion data: " + errorMessage);
}

⇲ Tautan Github: Java

Payload sampel Android

Lihat contoh payload berikut untuk App Links, skema URI, dan deferred deep linking. Sampel berisi payload penuh, relevan ketika semua parameter di halaman penyiapan tautan kustom Onelink berisi data.

Catatan : Payload kembali sebagai peta. Namun, untuk kejelasan, contoh payload berikut ditampilkan dalam bentuk JSON.

Android App Links

Input ke onAppOpenAttribution(Map<String, String> attributionData)

{
    "af_dp": "afbasicapp://mainactivity",
    "af_ios_url": "https://isitchristmas.com/",
    "fruit_name": "apples",
    "c": "fruit_of_the_month",
    "media_source": "Email",
    "link": "https://onelink-basic-app.onelink.me/H5hv/6d66214a",
    "pid": "Email",
    "af_cost_currency": "USD",
    "af_sub1": "my_sub1",
    "af_click_lookback": "20d",
    "af_adset": "my_adset",
    "af_android_url": "https://isitchristmas.com/",
    "af_sub2": "my_sub2",
    "fruit_amount": 26,
    "af_cost_value": 6,
    "campaign": "fruit_of_the_month",
    "af_channel": "my_channel",
    "af_ad": "my_adname",
    "is_retargeting": "true"
}
{
    "af_dp": "afbasicapp://mainactivity",
    "install_time": "2020-08-06 06:56:02",
    "fruit_name": "apples",
    "af_ios_url": "https://my_ios_lp.com",
    "media_source": "Email",
    "scheme": "https",
    "link": "https://onelink-basic-app.onelink.me/H5hv?pid=Email&c=fruit_of_the_month&af_channel=my_channel&af_adset=my_adset&af_ad=my_adname&af_sub1=my_sub1&af_sub2=my_sub2&fruit_name=apples&fruit_amount=16&af_cost_currency=USD&af_cost_value=6&af_click_lookback=20d&af_dp=afbasicapp%3A%2F%2Fmainactivity&af_ios_url=https%3A%2F%2Fmy_ios_lp.com&af_android_url=https%3A%2F%2Fmy_android_lp.com",
    "af_cost_currency": "USD",
    "af_sub1": "my_sub1",
    "af_click_lookback": "20d",
    "path": "/H5hv",
    "af_adset": "my_adset",
    "af_android_url": "https://my_android_lp.com",
    "af_sub2": "my_sub2",
    "fruit_amount": 16,
    "af_cost_value": 6,
    "host": "onelink-basic-app.onelink.me",
    "campaign": "fruit_of_the_month",
    "af_channel": "my_channel",
    "af_ad": "my_adname"
}

URI schemes

Input ke onAppOpenAttribution(Map<String, String> attributionData)

{
    "scheme": "afbasicapp",
    "link": "afbasicapp://mainactivity?af_ad=my_adname&af_adset=my_adset&af_android_url=https%3A%2F%2Fmy_android_lp.com&af_channel=my_channel&af_click_lookback=25d&af_cost_currency=NZD&af_cost_value=5&af_deeplink=true&af_dp=afbasicapp%3A%2F%2Fmainactivity&af_force_deeplink=true&af_ios_url=https%3A%2F%2Fmy_ios_lp.com&af_sub1=my_sub1&af_sub2=my_sub2&af_web_id=367f81fb-59a4-446a-ac6c-a68d2ee9447c-p&campaign=my_campaign&fruit_amount=15&fruit_name=apples&is_retargeting=true&media_source=Email&shortlink=9270d092",
    "af_cost_currency": "NZD",
    "af_click_lookback": "25d",
    "af_deeplink": true,
    "path": "",
    "af_android_url": "https://my_android_lp.com",
    "af_force_deeplink": true,
    "fruit_amount": 15,
    "host": "mainactivity",
    "af_channel": "my_channel",
    "shortlink": "9270d092",
    "af_dp": "afbasicapp://mainactivity",
    "install_time": "2020-08-06 06:56:02",
    "af_ios_url": "https://my_ios_lp.com",
    "fruit_name": "apples",
    "af_web_id": "367f81fb-59a4-446a-ac6c-a68d2ee9447c-p",
    "media_source": "Email",
    "af_status": "Non-organic",
    "af_sub1": "my_sub1",
    "af_adset": "my_adset",
    "af_sub2": "my_sub2",
    "af_cost_value": 5,
    "campaign": "my_campaign",
    "af_ad": "my_adname",
    "is_retargeting": true
}
{
    "af_dp": "afbasicapp://mainactivity",
    "install_time": "2020-08-06 06:56:02",
    "af_ios_url": "https://my_ios_lp.com",
    "fruit_name": "apples",
    "af_web_id": "367f81fb-59a4-446a-ac6c-a68d2ee9447c-p",
    "scheme": "afbasicapp",
    "media_source": "Email",
    "link": "afbasicapp://mainactivity?af_ad=my_adname&af_adset=my_adset&af_android_url=https%3A%2F%2Fmy_android_lp.com&af_channel=my_channel&af_click_lookback=25d&af_cost_currency=NZD&af_cost_value=5&af_deeplink=true&af_dp=afbasicapp%3A%2F%2Fmainactivity&af_ios_url=https%3A%2F%2Fmy_ios_lp.com&af_sub1=my_sub1&af_sub2=my_sub2&af_web_id=367f81fb-59a4-446a-ac6c-a68d2ee9447c-p&campaign=my_campaign&fruit_amount=15&fruit_name=apples&is_retargeting=true&media_source=Email",
    "af_cost_currency": "NZD",
    "af_status": "Non-organic",
    "af_click_lookback": "25d",
    "af_sub1": "my_sub1",
    "af_deeplink": true,
    "path": "",
    "af_android_url": "https://my_android_lp.com",
    "af_adset": "my_adset",
    "fruit_amount": 15,
    "af_sub2": "my_sub2",
    "host": "mainactivity",
    "af_cost_value": 5,
    "campaign": "my_campaign",
    "af_channel": "my_channel",
    "af_ad": "my_adname",
    "is_retargeting": true
}

Deferred deep linking

Input ke onConversionDataSuccess(Map<String, Object> conversionData)

{
    "redirect_response_data": null,
    "adgroup_id": null,
    "engmnt_source": null,
    "retargeting_conversion_type": "none",
    "orig_cost": 6.0,
    "af_cost_currency": "USD",
    "is_first_launch": true,
    "af_click_lookback": "20d",
    "af_cpi": null,
    "iscache": true,
    "click_time": "2020-08-12 16:04:50.605",
    "af_android_url": "https://isitchristmas.com/",
    "fruit_amount": 26,
    "is_branded_link": null,
    "match_type": "probabilistic",
    "adset": null,
    "af_channel": "my_channel",
    "campaign_id": null,
    "shortlink": "6d66214a",
    "af_dp": "afbasicapp://mainactivity",
    "install_time": "2020-08-12 16:05:33.750",
    "af_ios_url": "https://isitchristmas.com/",
    "fruit_name": "apples",
    "media_source": "Email",
    "agency": null,
    "af_siteid": null,
    "af_status": "Non-organic",
    "af_sub1": "my_sub1",
    "cost_cents_USD": 600,
    "af_sub5": null,
    "af_adset": "my_adset",
    "af_sub4": null,
    "af_sub3": null,
    "af_sub2": "my_sub2",
    "adset_id": null,
    "esp_name": null,
    "af_cost_value": 6,
    "campaign": "fruit_of_the_month",
    "http_referrer": "android-app://com.slack/",
    "af_ad": "my_adname",
    "is_universal_link": null,
    "is_retargeting": true,
    "adgroup": null
}