Android極光推送處理message遇到的坑解決
正文
我相信現在絕大部分App幾乎避免不瞭消息推送,其實原理還是使用瞭長連接,通過服務端將消息推給客戶端。市面上也有不少三方庫,例如極光、友盟、個推、阿裡等等。今天我就分享一下我在使用極光推送時遇到的坑,希望對大傢有所幫助。
極光推送的接入和使用這裡就不展開說明,咱們直接進入主題。因為項目使用的是通知欄方式,就是手機會先收到一個通知欄,用戶點擊通知欄跳轉對應頁面。
在點擊這個通知欄時會觸發其中onNotifyMessageOpened方法,後端會把我們所需要的內容放在message中。其實也就是個json字符串,我們拿到後需要通過對它解析拿到我們所需數據。
override fun onNotifyMessageOpened( context: Context?, message: NotificationMessage ) { val title = message.notificationTitle//通知欄標題 val content = message.notificationContent//通知欄內容 val json = message.notificationExtras//推送信息 }
到這裡都還一帆風順,接下來就出現問題瞭,明明日志獲取到瞭對應信息,但解析後使用卻是空:
val fromJson = gson.fromJson(json, Bean::class.java)
我打印瞭一下json信息:
{"data":"{\"type\":1,\"name\":\"張三\"}"}
很明顯,data內部隻能識別出一個字符串。所以我們無法拿到內部的type和name屬性。經過瞭解後才知道,後端設置notificationExtras時隻能設置為Sting類型,然而notificationExtras已經是實體內的一個屬性,所以我們拿到的時候其實json已經被轉義瞭。那麼怎麼解決呢?其實把data的值再一次通過Gson解析就能拿到數據瞭。我們這裡采取Map來解析:
其實如果使用Gson解析就不會再出現坑,因為使用Map後面還有坑,所以這裡接著使用Map來解析。
val map = Gson().fromJson<HashMap<String, Any>>( fromJson.data, HashMap::class.java )
通過上面的json信息其實不難發現,data內部隻有兩個屬性,一個int類型的type,一個Sting類型的name。然而,這裡的坑又出現瞭……
眼尖的同學估計已經發現問題瞭,一個int類型的數據竟然給我轉換成Double類型的數據瞭,不得不說這很不嚴謹。難道是自己哪裡沒操作對嗎?最後通過查閱資料發現,這是Gson的坑,不僅僅是int,連Long也會被轉換為Double,這一點讓人很難接受。如何解決?
- 自定義Gson的TypeAdapter,具體實現可以查閱資料
- 拋棄Gson,擁抱阿裡,使用FastJson
到此,我們便拿到瞭期望的數據。這裡還要提一點,關於通知消息跳轉Acticity棧頂的配置。如果當前正在目標頁面,那麼我們一定不希望重新創建新的頁面,而是希望在當前頁面刷新數據即可。所以不要忘記給目標頁面配置棧頂模式,重寫OnNewIntent方法。
另外,在廣播中跳轉Activity時,一定不要忘記給Intent設置flags。
intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK
總結
在json解析這塊其實經常出現一些問題,例如後端鍵名多瞭一個空格、某個屬性的文字格式不對等等。這些雖說要盡量避免,但也難免會發生。這時我們應該冷靜下來分析問題,多打斷點。很多問題都會在心細下迎刃而解,希望以上分享對大傢有所幫助!
更多關於Android message坑的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- Gson之toJson和fromJson方法的具體使用
- 詳解Android的四大應用程序組件
- JSON序列化導致Long類型被搞成Integer的坑及解決
- Android入門之在Activity之間穿梭的Intent
- Android廣播實現App開機自啟動