本文已首發微信公眾號「code小生」,大家可以搜索關注,專注安卓技術分享,
由來
前段時間給APP增加推送功能,經調研后接收到的結果是集成個推SDK,這從市場使用概率來看很不錯,畢竟個推、騰訊TPNS(原名信鴿)、極光、友盟等都是比較流行的廠家服務,但對于開發者來講,更重要的是官方檔案是否易于閱讀?官方客服溝通起來是否便捷? ,一份優秀的檔案說明可以節約很大的成本,相信各位開發者深有感觸吧,
問題產生
個推Android集成官方檔案:https://docs.getui.com/getui/mobile/android/androidstudio/
按照上述檔案集成完畢后,無論哪款機型,總是獲取不到廠商token,但clientId可以獲取到,這是問題一,
廠商token有如下兩種查看方式,這兩種方式并不在集成檔案里,而是在Android常見問題里,
- 手機連接電腦,手機需開啟開發者除錯模式,打開APP,在androidstudio編譯器logcat中過濾"Assist_",若成功列印token資訊則表示廠商集成正常,
- 在個推后臺【訊息推送】-【配置管理】-【應用配置】中正常填寫保存廠商引數,然后在個推后臺【訊息推送】-【配置管理】-【故障排查】-【檢測CID的狀態及資訊:】中輸入CID查詢,看是否會回傳廠商token,
其實還有一種方式,就是官方API提供的介面
public void onReceiveDeviceToken(Context context, String deviceToken),但是該介面不是非必須實作的,而這個方法的回呼前提是已經獲得了廠商token,所以也不能排查啥問題,
從上面兩種方式中細心的你應該注意到了細節:廠商集成和保存廠商引數,
關于保存廠商引數這個很明確,在后臺就可以看到,目前只提供了主流手機廠商通道(華為、小米、OPPO、VIVO、海外通道)的配置,如圖:

我們需要做的就是在各個應用市場找到我們的應用(因為我的應用是已經上架的,如果是新創建,那么建議在創建的時候就打開)并為其打開推送服務就可以了;需要注意的是,華為需要多一步:在應用的簽名資訊里配置SHA256的值(如何獲取已經上架應用的SHA256的值,華為有給教程哈,很nice),
這一步還是獲取不到廠商token,由此帶來的體驗是:
服務端發送推送,手機端在線時可以收到,離線后就收不到,而服務端的發送代碼是同時發送了通知和透傳訊息,所以服務端的發送代碼不準備修改,是參照demo里寫的,
這里又有一個問題,什么是透傳訊息?該如何理解透傳?
關于透傳訊息,正確的理解是個推和手機廠商合作,所發出的訊息會走各個手機廠商的通道,而不僅僅是個推自家的通道,透傳并沒有“穿透、強度、力度、高級”方面的意思,千萬別誤解了,透傳訊息和通知是同級別的不同種類訊息送達方式而已,
由于我是第一次集成,專案也是幫忙做,就沒細看太多,只取了集成需要的東西,好處是相關人員拉了個個推官方的技術支持群,所以后面我扔了很多問題,但基本答非所問,
再前面配置廠商引數的時候我也注意到oppo還是vivo在打開推送服務的時候,會有透傳訊息的解釋,當時我就感覺后端對我的引導有偏差,經過和技術支持溝通,確定的結果如下:
- 透傳訊息只能在線接收到,離線根本就不會收到透傳訊息
- 離線能收到的是通知,和透傳訊息無關
這下就明確了,在這之前的做法是一直糾結為什么離線收不到透傳訊息,因為后端給我的錯誤引導是透傳應該是離線的時候收到的,它有穿透之意,比通知更高級,這就是我為什么在前面要強調對透傳的理解,
進一步根據技術支持的反饋,通知的顯示和點擊是不需要客戶端做處理的,只需要客戶端嚴格按照檔案要求配置icon和文本、服務端在發送通知的時候指定跳轉頁面即可,如果不指定跳轉頁面默認跳轉APP首頁,而透傳訊息的顯示需要客戶端做處理,也就是顯示通知欄的操作,但點擊跳轉作業同樣不需要客戶端去做,
探尋解決方案
到這里,基本的思路和邏輯清楚了,但依然有兩個問題未解決:
- 廠商集成如何做?在哪里?
- 為什么獲取不到設備token?根據官方提示,如果獲取不到設備token,那肯定app離線時收不到通知,
這兩個問題都是APP離線時才會觸發,其實這兩個問題歸根結底還是同一個問題,就是廠商未集成,那么問題來了,我翻遍了個推Android集成檔案 也就是本文開始給出的鏈接,但就是找不到集成廠商的步驟,接下來就入坑了,我在各個應用市場翻閱了推送服務相關檔案、檢查了各個推送服務的配置開關、嘗試release測驗、換主流手機測驗、詢問官方技術支持,但都一無所獲,技術支持最多的一句回復就是讓我看這個:

這個截圖其實就是Android常見問題中的第四個問題,
但這不是扯呢么,問題我知道在哪,我就是想知道廠商集成在哪里?我要檔案或者鏈接,最后實在不行了,準備做最后的決戰,直接@個推官方技術支持直接要鏈接,結果給我扔出來一個從未謀面的鏈接:https://docs.getui.com/getui/mobile/vendor/androidstudio/ 打開后發現,這太坑了吧,瞬間想罵兩句,但還是忍住了,因為我最近正在看一本書《人生處處是修行》哈哈,
我們來看下官方檔案的整體分布:

Android和多廠商居然是平級關系,更可恨的是集成多廠商之前必須先集成Android個推SDK,也就是我們前面做過的作業,那么接下來就集成唄,照著檔案完畢后在控制臺果然看到了夢寐以求的device token ,然后再去根據 clientId 查詢廠商token,果然有值,需要注意的是離線的測驗必須是官方支持的主流機型(前面配置過的機型),華為的需要是release版本才可以測驗結果,
解決問題后,跟官方技術支持提供了建議:
應該在Android集成檔案里面提及到多廠商集成,或者至少加個超鏈接吧,得到的回復是他們建議一下,我就知道他們多半不是直接的個推官方技術,
總結
這次之所以爬坑最主要的失誤有兩個;
- 沒有提前了解相關術語的目的,被誤解帶偏
- 對于提供的技術支持要有正確的認識(很多其實都是商務,不是官方直接的技術)
額外提及一點,在集成多廠商的時候,碰到關于服務端配置訊息(通知和透傳訊息)點擊事件的intent值,官方文檔有如下描述:

圖中紅色部分的配置方式正式Android集成檔案里提及的方式,而這里又不建議使用,這不是坑人嘛!我為了安全起見,根據官方提供的生成方式,在安卓端生成后發給后端使用,
各位如遇到如上問題希望這里能幫到你,本文已結束,
我是code小生,喜歡可以隨手點個
贊、評論一下,謝謝~
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/300777.html
標籤:其他
