HUAWEI Ads Kit獲取轉化跟蹤參數(AIDL方式),華為推快遞服務push kitHUAWEI Ads Kit獲取轉化跟蹤參數(AIDL方式)使用場景廣告主App開發者也可直接調用廣告服務(HUAWEI Ads Kit)的AIDL接口獲取華為設備上的轉化跟蹤參數,這種集成方式不需要集成任何華為SDK。AIDL......
使用場景
廣告主App開發者也可直接調用廣告服務(HUAWEI Ads Kit)的AIDL接口獲取華為設備上的轉化跟蹤參數,這種集成方式不需要集成任何華為SDK。AIDL接口獲取到的轉化跟蹤參數與同一臺設備上SDK接口獲取到的轉化跟蹤參數相同。
調用流程
開發步驟
1.創建接口IPPSChannelInfoService的AIDL文件,放置在com.huawei.android.hms.ppskit包路徑下,如下圖:
2.將以下內容復制到AIDL文件中。
package com.huawei.android.hms.ppskit;
/**重要:請不要修改此AIDL文件的方法順序*/
interface IPPSChannelInfoService{
String getChannelInfo();
}
3.創建一個類,實現Android原生的ServiceConnection接口。
a.實現ServiceConnection的onServiceConnected方法。
b.調用Android原生的IPPSChannelInfoService.Stub.asInterface方法獲取IPPSChannelInfoService。
c.調用getChannelInfo方法獲取轉化跟蹤參數。
private static final String TAG = InstallReferrerAidlActivity;
private final class InstallReferrerServiceConnection implements ServiceConnection {
private InstallReferrerServiceConnection() {
}
@Override
public void onServiceConnected(ComponentName componentName, IBinder iBinder) {
Log.i(TAG, onServiceConnected);
IPPSChannelInfoService service = IPPSChannelInfoService.Stub.asInterface(iBinder);
if (null != service) {
try {
String json = service.getChannelInfo();
parseChannelJson(json);
} catch (RemoteException e) {
Log.e(TAG, getChannelInfo Exception);
} finally {
getApplicationContext().unbindService(this);
}
}
}
@Override
public void onServiceDisconnected(ComponentName componentName) {
Log.i(TAG, onServiceDisconnected);
}
}
}
4.連接轉化跟蹤參數的AIDL服務。
private boolean bindService() {
// 創建一個InstallReferrerServiceConnection實例
InstallReferrerServiceConnection serviceConnection = new InstallReferrerServiceConnection();
// 創建一個Intent,Action是“com.huawei.android.hms.CHANNELSERVICE”
Intent intent = new Intent(com.huawei.android.hms.CHANNELSERVICE);
// 設置Intent的包名為”com.huawei.hwid”
intent.setPackage(com.huawei.hwid);
// 調用bindService連接轉化跟蹤參數的AIDL服務
boolean result = bindService(intent,serviceConnection,Context.BINDAUTOCREATE);
Log.i(TAG, bindService result: + result);
return result;
}
5.解析返回的JSON格式寫轉化跟蹤參數。
private ReferrerDetails parseChannelJson(String channelJson) {
Log.i(TAG, parseChannelJson: + channelJson);
// 將JSON格式寫轉化跟蹤參數
try {
JSONObject jsonObject = new JSONObject(channelJson);
// 跟蹤參數
String channelInfo = jsonObject.optString(channelInfo);
// 安裝時間戳
long installTimestamp = jsonObject.optLong(installTimestamp, 0);
// 點擊時間戳
long clickTimestamp = jsonObject.optLong(clickTimestamp, 0);
ReferrerDetails referrerDetails = new ReferrerDetails(channelInfo, clickTimestamp, installTimestamp);
updateReferrerDetails(referrerDetails);
return referrerDetails;
} catch (JSONException e) {
Log.e(TAG, );
}
return null;
}
private void updateReferrerDetails(final String installReferrer, final long clickTimestamp,final long installTimestamp) {
Log.i(TAG, installReferrer: + installReferrer + , clickTimestamp: + clickTimestamp + , installTimestamp: + installTimestamp);
}
特別聲明:以上文章內容僅代表作者本人觀點,不代表ESG跨境電商觀點或立場。如有關于作品內容、版權或其它問題請于作品發表后的30日內與ESG跨境電商聯系。
二維碼加載中...
使用微信掃一掃登錄
使用賬號密碼登錄
平臺顧問
微信掃一掃
馬上聯系在線顧問
小程序
ESG跨境小程序
手機入駐更便捷
返回頂部