上周,公司要實(shí)現(xiàn)推送通知的功能,并決定在項(xiàng)目中集成友盟推送的 SDK來(lái)代替之前集成的云巴推送。
云巴推送是什么鬼?讓我們來(lái)看看它的功能和使用場(chǎng)景。
云巴是一個(gè)覆蓋全國(guó)(即將覆蓋美國(guó)歐洲)的實(shí)時(shí)消息發(fā)布訂閱系統(tǒng),可以以毫秒級(jí)的速度向百萬(wàn)乃至千萬(wàn)終端用戶發(fā)送大量的消息。云巴適用于對(duì)實(shí)時(shí)性和到達(dá)率要求高的應(yīng)用、游戲、設(shè)備。云巴支持手機(jī)、平板、筆記本、智能硬件、智能家居等作為終端。
云巴在 Github 上開(kāi)源地址,云巴使用輕量級(jí)的 MQTT 作為協(xié)議,主要編程語(yǔ)言為 Erlang。云巴支持 IOS, Android, JavaScript, Socket.IO, PHP, C, C#等語(yǔ)言,可以從任一終端向另一終端發(fā)送消息。
云巴的特點(diǎn)是:高并發(fā)、低耗費(fèi)、毫秒級(jí)、跨平臺(tái)、跨設(shè)備、跨語(yǔ)言。
云巴的應(yīng)用場(chǎng)景包括:雙向消息推送,私信,即時(shí)聊天,多人大型游戲,租車(chē)打車(chē)通知,遠(yuǎn)程攝像頭控制,遠(yuǎn)程開(kāi)關(guān)空調(diào),實(shí)時(shí)更新股票走勢(shì),實(shí)時(shí)更新庫(kù)存量,活動(dòng)文字直播,實(shí)時(shí)地理位置地圖,智能硬件的 APP 控制,實(shí)時(shí)統(tǒng)計(jì)圖表。
其實(shí)云巴和友盟在實(shí)現(xiàn)推送功能方面沒(méi)什么太大區(qū)別,只是因?yàn)樵瓢屯扑褪窃陧?xiàng)目趕工期時(shí)的產(chǎn)品,具體的交互界面以及參數(shù)都沒(méi)來(lái)得及定!所以推送在本次開(kāi)發(fā)任務(wù)中交給了不大熟知云巴的我來(lái)做,因此換成了被大家熟悉且曾經(jīng)集成過(guò)的友盟推送!
下面介紹一些集成中常出的問(wèn)題以及自己出現(xiàn)的問(wèn)題:
1.友盟后臺(tái)添加新應(yīng)用,需要上傳 P12文件,而 pem 文件是不能上傳成功的(本人沒(méi)有上傳成功)
本人從鑰匙串中導(dǎo)出文件是只能導(dǎo)出為 pem 文件,但是導(dǎo)出的 pem 文件卻不能被友盟后臺(tái)識(shí)別轉(zhuǎn)換
后來(lái)發(fā)現(xiàn)所導(dǎo)出的證書(shū)下面缺少了私鑰,并且左側(cè)沒(méi)有三角標(biāo)識(shí),如下圖:
于是使用公司的蘋(píng)果開(kāi)發(fā)者帳號(hào)里面重新生成了一套 SSL證書(shū)(包含私鑰,呈現(xiàn)下三角標(biāo)識(shí)),如下圖:
左側(cè)的三角標(biāo)識(shí)顯示為上圖狀況時(shí),導(dǎo)出的p12文件才是友盟后臺(tái)所需要的證書(shū)文件(而非鑰匙串的 p12文件),把導(dǎo)出的 p12文件(設(shè)置密碼*****)上傳到友盟后臺(tái),并在相應(yīng)位置輸入剛才設(shè)置的相對(duì)應(yīng)證書(shū)的密碼即可添加應(yīng)用成功;
隨后就可以在 ?應(yīng)用信息 ?一欄中查看應(yīng)用剛剛添加的應(yīng)用的 Appkey 和 AppMaster Secret,并可以設(shè)置公司推送服務(wù)器的IP 地址
2.通過(guò) DeviceToken在友盟后臺(tái)添加測(cè)試設(shè)備
查看友盟官方相關(guān)deviceToken問(wèn)題的論壇
1)使用didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)token獲取 token并使用 NSLog 方法打印出來(lái),但是打印出來(lái)的 token 如下圖:
2)此時(shí)把以上字符串復(fù)制粘貼到圖2.1的空格中,會(huì)標(biāo)紅報(bào)錯(cuò)——Device Token不能包含特殊字符,
分析原因得知:剛才拷貝的內(nèi)容包含尖括號(hào)<>以及空格,所以處理辦法是——去掉<>和空格后;
3)根據(jù)上一步分析,在圖2.1空白處將拷貝的內(nèi)容修改過(guò)后,發(fā)現(xiàn)仍然報(bào)錯(cuò)——Device Token長(zhǎng)度錯(cuò)誤
分析原因得知:第一步拷貝到2.1圖中空白處的內(nèi)容因?yàn)榘崭窈图饫ㄌ?hào),所以長(zhǎng)度已經(jīng)超出了64,達(dá)到了73,而空白處提示 "輸入64位***",所以此處拷貝過(guò)來(lái)的內(nèi)容已經(jīng)被截取了前64位,導(dǎo)致后面的一些字符串被刪除掉了,即使刪除了尖括號(hào)和空格,就會(huì)導(dǎo)致被自動(dòng)截取的前64位中有效的字符串(非空格,非尖括號(hào))不足64位, 所以最有效的處理方法就是———從 1)中拷貝的 token 去除尖括號(hào)以及空格
于是獲取 token 的方法就使用如下方法:
DeLog(@"UmengDeviceToken-%@",[[[[deviceToken description] stringByReplacingOccurrencesOfString: @"<" withString: @""]
stringByReplacingOccurrencesOfString: @">" withString: @""]
stringByReplacingOccurrencesOfString: @" " withString: @""]);
4)通過(guò)3)獲取的 token 拷貝粘貼到空白處,并填寫(xiě)設(shè)備名稱(chēng)加以區(qū)分,即可添加成功測(cè)試設(shè)備。
3.友盟后臺(tái)測(cè)試單播和自定義播(alias)都能成功,而公司服務(wù)器測(cè)試單播可成功,而 alias 報(bào)2010錯(cuò)誤
查看友盟與Alias對(duì)應(yīng)的Device_token 為空的官方論壇 && 單播可收到,廣播收不到的官方論壇
1)檢查 iOS 客戶端代碼是否設(shè)置別名成功
客戶端設(shè)置別名(Alias)代碼如下:
[UMessage setAlias:@"alias1310" type:@"alias" response:^(id? _Nonnull responseObject, NSError * _Nonnull error) {
DeLog(@"成功返回?cái)?shù)據(jù)--%@",responseObject);
}];
并且打印信息顯示:成功返回?cái)?shù)據(jù)--{success = ok}?
2)通過(guò)友盟后臺(tái)的工具檢測(cè)設(shè)置的 alias 是否成功
3)因?yàn)榘沧慷?OK,考慮到安卓和 iOS 的后臺(tái)是分開(kāi)集成的,所以讓后臺(tái)人員配合檢查其后臺(tái)相關(guān)代碼
后臺(tái)人員檢查無(wú)誤!!!
4)鬧心有木有,到底哪里出了問(wèn)題呢??
有點(diǎn)信不過(guò)后臺(tái)哥們,于是跑到后臺(tái)看他們的代碼以及相關(guān)文檔如下:
他們也有個(gè) alias_type:"xx",閱讀后面描述發(fā)現(xiàn)端倪,于是查看后臺(tái)代碼中alias_type 值發(fā)現(xiàn):我的代碼中的 type 類(lèi)型值 和后臺(tái)的竟然沒(méi)有統(tǒng)一寫(xiě)成一致的,是不是這個(gè)問(wèn)題導(dǎo)致的呢???
于是飛速再鍵盤(pán)上敲下了相同的 alias_type 值,經(jīng)過(guò)測(cè)試發(fā)現(xiàn) OK 啦! ?報(bào)的錯(cuò)誤和真正的問(wèn)題根源還是不大一樣的!哦耶
4.自定義彈框偶爾 會(huì)彈出兩個(gè)彈框——自定義的彈框+友盟的默認(rèn)彈框
這個(gè)問(wèn)題最初沒(méi)有發(fā)現(xiàn),后來(lái)有一次做斷點(diǎn)調(diào)試的過(guò)程中,發(fā)現(xiàn):兩個(gè)彈框的Bug必現(xiàn)?。。。。?/p>
1)因?yàn)闇y(cè)試機(jī)是 iOS10以下系統(tǒng),所以在方法 代理方法 didReceiveRemoteNotification: fetchCompletionHandler: 中查看是否關(guān)閉友盟彈框
如果是 iOS10系統(tǒng),需要再方法userNotificationCenter: willPresentNotification: withCompletionHandler: 中查看是否關(guān)閉友盟彈框
結(jié)果如下圖:
2)查看 友盟推送demo中的代碼,是否調(diào)用了相同的方法
結(jié)果如下圖:
比較二者,有沒(méi)有發(fā)現(xiàn)二者的區(qū)別;兩個(gè)方法的調(diào)用順去顛倒也會(huì)出現(xiàn) Bug 的,瞬間解決,哦耶?。。?/p>
5.在友盟后臺(tái)測(cè)試推送通知時(shí),客戶端經(jīng)常收不到通知!!!
1)請(qǐng)?zhí)D(zhuǎn)到知乎相關(guān)網(wǎng)址去查找相對(duì)應(yīng)的原因;
2)網(wǎng)絡(luò)很差,推送有延遲,稍等1-3分鐘即可收到;
這就是目前在集成友盟推送的開(kāi)發(fā)過(guò)程中遇到的一些小插曲,
希望有同樣的問(wèn)題的人可以通過(guò)以上解決方法能夠順利解決!!謝謝
如有更多問(wèn)題請(qǐng)移步到 【友盟+】消息推送常見(jiàn)問(wèn)題索引