iOS用戶行為統(tǒng)計工具開發(fā)-無侵入埋點

用戶行為統(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)計包含功能有:

  1. 統(tǒng)計用戶打開、退出APP應(yīng)用時刻搂誉,使用應(yīng)用的時長徐紧;
  2. 統(tǒng)計用戶打開頁面的時刻,停留的時長;
  3. 統(tǒng)計用戶使用的功能及使用時刻并级;
  4. 統(tǒng)計奔潰日志拂檩,奔潰時刻;
  5. 所有統(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ù)驾诈。

  • 三、 使用說明

  1. 添加統(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)計名稱使用猛们。

  2. 初始化統(tǒng)計類
    在程序啟動時初始化統(tǒng)計類,調(diào)用方法如下圖狞洋,需要修改初始化配置時可查看API根據(jù)使用需求配置弯淘。


    圖片 2.png
  3. 需要統(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)步恶导!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末浆竭,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子惨寿,更是在濱河造成了極大的恐慌邦泄,老刑警劉巖,帶你破解...
    沈念sama閱讀 223,002評論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件裂垦,死亡現(xiàn)場離奇詭異顺囊,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)缸废,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評論 3 400
  • 文/潘曉璐 我一進(jìn)店門包蓝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來驶社,“玉大人,你說我怎么就攤上這事测萎⊥龅纾” “怎么了?”我有些...
    開封第一講書人閱讀 169,787評論 0 365
  • 文/不壞的土叔 我叫張陵硅瞧,是天一觀的道長份乒。 經(jīng)常有香客問我,道長腕唧,這世上最難降的妖魔是什么或辖? 我笑而不...
    開封第一講書人閱讀 60,237評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮枣接,結(jié)果婚禮上颂暇,老公的妹妹穿的比我還像新娘。我一直安慰自己但惶,他們只是感情好耳鸯,可當(dāng)我...
    茶點故事閱讀 69,237評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著膀曾,像睡著了一般县爬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上添谊,一...
    開封第一講書人閱讀 52,821評論 1 314
  • 那天财喳,我揣著相機(jī)與錄音,去河邊找鬼斩狱。 笑死耳高,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的喊废。 我是一名探鬼主播祝高,決...
    沈念sama閱讀 41,236評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼污筷!你這毒婦竟也來了工闺?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,196評論 0 277
  • 序言:老撾萬榮一對情侶失蹤瓣蛀,失蹤者是張志新(化名)和其女友劉穎陆蟆,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惋增,經(jīng)...
    沈念sama閱讀 46,716評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡叠殷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,794評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了诈皿。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片林束。...
    茶點故事閱讀 40,928評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡像棘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出壶冒,到底是詐尸還是另有隱情缕题,我是刑警寧澤,帶...
    沈念sama閱讀 36,583評論 5 351
  • 正文 年R本政府宣布胖腾,位于F島的核電站烟零,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏咸作。R本人自食惡果不足惜锨阿,卻給世界環(huán)境...
    茶點故事閱讀 42,264評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦赴恨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,755評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽酵使。三九已至,卻和暖如春焙糟,著一層夾襖步出監(jiān)牢的瞬間口渔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,869評論 1 274
  • 我被黑心中介騙來泰國打工穿撮, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留缺脉,地道東北人。 一個月前我還...
    沈念sama閱讀 49,378評論 3 379
  • 正文 我出身青樓悦穿,卻偏偏與公主長得像攻礼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子栗柒,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,937評論 2 361

推薦閱讀更多精彩內(nèi)容