首頁 > 軟體

Android極光推播處理message遇到的坑解決

2023-02-28 18:00:26

正文

我相信現在絕大部分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,這一點讓人很難接受。如何解決?

  • 自定義GsonTypeAdapter,具體實現可以查閱資料
  • 拋棄Gson,擁抱阿里,使用FastJson

到此,我們便拿到了期望的資料。這裡還要提一點,關於通知訊息跳轉Acticity棧頂的設定。如果當前正在目標頁面,那麼我們一定不希望重新建立新的頁面,而是希望在當前頁面重新整理資料即可。所以不要忘記給目標頁面設定棧頂模式,重寫OnNewIntent方法。

另外,在廣播中跳轉Activity時,一定不要忘記給Intent設定flags。

intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK

總結

在json解析這塊其實經常出現一些問題,例如後端鍵名多了一個空格、某個屬性的文字格式不對等等。這些雖說要儘量避免,但也難免會發生。這時我們應該冷靜下來分析問題,多打斷點。很多問題都會在心細下迎刃而解,希望以上分享對大家有所幫助!

更多關於Android message坑的資料請關注it145.com其它相關文章!


IT145.com E-mail:sddin#qq.com