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:
- Pengguna mengklik URL pendek OneLink.
- Android meluncurkan aplikasi berdasarkan aktivitas yang relevan di AndroidManifest.xml.
- SDK AppsFlyer dipicu di aplikasi.
- 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.
- AppsFlyer SDK triggers
onAppOpenAttribution()
with the retrieved parameters and cached attribution parameters (e.g.install_time
). - Asynchronously,
onConversionDataSuccess()
is called, holding the full cached attribution data. (You can exit this function by checking ifis_first_launch
istrue
.) 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
- Memutuskan perilaku aplikasi dan
deep_link_value
(and other parameter names and values) - with the marketer - Input metode perencanaan, yaitu
deep_link_value
(and other parameter names and values) - with the marketer - Menerapkan
onAppOpenAttribution()
logic - 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 AplikasiLaunchMode
tidak standar.
Untuk memperbaikinya, hubungisetIntent(intent)
metode untuk mengatur nilai maksud di dalam metode yang digantionNewIntent
jika aplikasi menggunakan non-standarLaunchMode
.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:
- Pengguna mengklik OneLink di perangkat yang tidak menginstal aplikasi.
- AppsFlyer mendaftarkan klik dan mengarahkan pengguna ke app store atau halaman arahan yang benar.
- Pengguna menginstal aplikasi dan meluncurkannya.
- SDK AppsFlyer diinisialisasi dan pemasangan diatribusikan di server AppsFlyer.
- The SDK triggers the
onConversionDataSuccess
method. The function receives input that includes both thedeep_link_value
, and the attribution data/parameters defined in the OneLink data. - Parameter
is_first_launch
has the valuetrue
, yang menandakan alur deferred deep link.
Pengembang menggunakan data yang didapatkan dionConversionDataSuccess
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.
- Memutuskan perilaku aplikasi pada peluncuran pertama, dan
deep_link_value
(and other parameter names and values) - with the marketer - Input metode perencanaan, yaitu
deep_link_value
(and other parameter names and values) - with the marketer - Menerapkan
onConversionDataSuccess()
logic - 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:
- Beri tahu pemasar parameter dan nilai apa yang diperlukan untuk menerapkan perilaku aplikasi yang diinginkan.
- 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 :
- Menerapkan logika berdasarkan parameter dan nilai yang dipilih. Lihat contoh kode berikut.
- 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
}
Diperbarui 11 bulan yang lalu