用戶行為統(tǒng)計(User Behavior Statistics, UBS)一直是移動互聯(lián)網(wǎng)產(chǎn)品中必不可少的環(huán)節(jié)踩叭,也俗稱埋點怜俐。其實現(xiàn)在用戶統(tǒng)計的三方SDK很多制圈,那為什么還要自己做呢?主要原因是自己做定制化程度高侯养,靈活性大慕淡,而且統(tǒng)計數(shù)據(jù)不會外露。
近期被要求通過配置的方法進(jìn)行用戶行為統(tǒng)計沸毁,而不要將大量代碼添加到統(tǒng)計的頁面或者功能中峰髓,以此便于統(tǒng)一使用統(tǒng)計工具。
針對該需求筆者基于Aspects庫開發(fā)了可通過配置方式進(jìn)行集成的用戶行為統(tǒng)計工具息尺。
iOS用戶行為統(tǒng)計工具說明
-
一携兵、 功能說明
用戶行為統(tǒng)計包含功能有:
- 統(tǒng)計用戶打開、退出APP應(yīng)用時刻搂誉,使用應(yīng)用的時長徐紧;
- 統(tǒng)計用戶打開頁面的時刻,停留的時長;
- 統(tǒng)計用戶使用的功能及使用時刻并级;
- 統(tǒng)計奔潰日志拂檩,奔潰時刻;
- 所有統(tǒng)計都通過配置的方式實現(xiàn)嘲碧,除統(tǒng)計
UITabBarViewController
的子控制器切換外稻励,不需要在統(tǒng)計類中添加代碼(統(tǒng)計UITabBarViewController
的子控制器切換時需實現(xiàn)其代理方法- (void)tabBarController:(UITabBarController*)tabBarController didSelectViewController:(UIViewController *)viewController;
并需要在配置文件中添加實現(xiàn)其代理的類)并且可高度定制和可控。
注:以上統(tǒng)計均可包含用戶信息愈涩、硬件信息和其他需要包含的固定信息望抽。
-
二、 原理說明
核心原理是利用Objective-C的運行時機(jī)制履婉,在程序運行時動態(tài)插入配置文件中的類名和方法名在原基類方法執(zhí)行之前煤篙,以此監(jiān)聽系統(tǒng)方法的調(diào)用執(zhí)行達(dá)到統(tǒng)計的目的。
核心實現(xiàn)文件由Aspects庫實現(xiàn)毁腿,其詳細(xì)實現(xiàn)邏輯可參考這篇博客辑奈。在封裝上,主要實現(xiàn)了頁面打開已烤,頁面關(guān)閉鸠窗,頁面停留時間,功能使用草戈,程序使用狀態(tài)的監(jiān)聽統(tǒng)計塌鸯,普通功能和頁面使用的統(tǒng)計直接調(diào)用Aspects的接口即可實現(xiàn);而涉及需要統(tǒng)計使用停留時長和
UITabBarViewController
子控制器切換的邏輯則稍微復(fù)雜些唐片。需要統(tǒng)計使用時長的目前有兩種丙猬,普通頁面使用停留時長,
UITabBarViewController
子控制器使用停留時長费韭。普通頁面停留時長在頁面控制器調(diào)用ViewDidLoad
時記錄開始時間茧球,在調(diào)用dealloc
方法時計算停留時間并做統(tǒng)計。UITabBarViewController
由于沒有可以直接監(jiān)聽子控制器切換的系統(tǒng)方法星持,只能通過監(jiān)聽其代理方法來實現(xiàn)抢埋,而默認(rèn)選中的第一個自控制器不會走代理方法需要在實現(xiàn)邏輯中預(yù)先做處理。由于要監(jiān)聽代理方法督暂,所以監(jiān)聽UITabBarViewController
子控制器切換時需要配置實現(xiàn)其代理方法的類用于監(jiān)聽揪垄。而停留時長的統(tǒng)計邏輯與普通頁面的實現(xiàn)類似,在統(tǒng)計時長時有兩種特殊情況需要處理逻翁,一種是使用過程中進(jìn)入后臺停留后又回到前臺饥努,一種是進(jìn)入后臺停留后退出程序。
所有的統(tǒng)計信息會先存入本地數(shù)據(jù)庫八回,根據(jù)選擇的發(fā)送策略自動選擇時間發(fā)送給后臺酷愧,發(fā)送成功后清除本地數(shù)據(jù)的統(tǒng)計數(shù)據(jù)驾诈。 -
三、 使用說明
-
添加統(tǒng)計配置
圖片 1.png
如圖1:
trackedPages為普通頁面統(tǒng)計溶浴,className為統(tǒng)計的頁面的控制器類名稱乍迄,pageName為該頁面的漢語名稱用于提交給后臺作為統(tǒng)計名稱使用;
trackedEvents為功能使用統(tǒng)計士败,如按鈕點擊闯两,手勢執(zhí)行等,className為統(tǒng)計功能的執(zhí)行類名稱(注:如UIButton的執(zhí)行者類為其添加執(zhí)行方法中的Target對象的類拱烁,通俗的講就是它的點擊方法在哪個類里實現(xiàn)的該類就是它的執(zhí)行類)生蚁,selector為統(tǒng)計功能的統(tǒng)計執(zhí)行方法噩翠,eventName為統(tǒng)計功能的漢語名稱用于提交后臺作為統(tǒng)計名稱使用戏自;
trackedTabBarEvents為
UITabBarViewController
的代理執(zhí)行統(tǒng)計,className為執(zhí)行其代理的類伤锚,該類需要執(zhí)行其代理方法- (void)tabBarController:(UITabBarController*)tabBarController didSelectViewController:(UIViewController *)viewController;
trackedTabBarSubVCEvent為
UITabBarViewController
的子控制器切換統(tǒng)計擅笔,item填寫的順序與實際添加子控制器順序相同,item中className為子控制器類名稱屯援,pageName為該頁面的漢語名稱用于提交給后臺作為統(tǒng)計名稱使用猛们。 -
初始化統(tǒng)計類
在程序啟動時初始化統(tǒng)計類,調(diào)用方法如下圖狞洋,需要修改初始化配置時可查看API根據(jù)使用需求配置弯淘。
圖片 2.png 需要統(tǒng)計
UITabBarViewController
子控制器切換時的代理實現(xiàn)
需要統(tǒng)計UITabBarViewController
子控制器切換時需要在設(shè)置UITabBarViewController對象的時候?qū)崿F(xiàn)其代理方法- (void)tabBarController:(UITabBarController*)tabBarController didSelectViewController:(UIViewController *)viewController;
并在配置文件中添加實現(xiàn)類的配置,添加操作可查看使用說明中第一條添加統(tǒng)計配置吉懊。
參考文檔
iOS 用戶行為統(tǒng)計代碼的剝離
禪與 Objective-C 編程藝術(shù)
Demo地址
Demo引用.a庫地址GitHub給個Star噢!
- 補(bǔ)充:關(guān)于H5的監(jiān)聽統(tǒng)計頁面跳轉(zhuǎn)可以通過監(jiān)聽webview代理方法中的URL包含的內(nèi)容實現(xiàn)庐橙,如
WKWebView
的代理方法
- (void) webView: (WKWebView *) webView decidePolicyForNavigationAction: (WKNavigationAction*) navigationAction decisionHandler: (void (^)(WKNavigationActionPolicy)) decisionHandler{
NSURL* url = [navigationAction.request URL]
}
或者UIWebView
的代理方法
- (BOOL)webView:(UIWebView *)theWebView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{
NSURL *url = [request URL];
}
,停留時間和原生界面邏輯基本相同。動作統(tǒng)計可以在javascript與webView之間定一個協(xié)議約定:document.location = "eventStatistic://"+"functionMethod"+"thisFunctionName"
,同樣在上述兩個方法中攔截URL中包含eventStatistic://
前綴的即可借嗽,后邊的方法名就可以截取作為上傳服務(wù)器使用态鳖。
喜歡就點個贊唄!
歡迎大家提出更好的改進(jìn)意見和建議,一起進(jìn)步恶导!