百度消息推送点击跳转到指定界面的实现

百度推送实现上面的功能,我自己在做的时候,按照api上面的介绍去实现,出现了很多的问题。

第一,在onNotificationClicked()方法里面,能获取到custom_content的参数,但是无法进行界面跳转

          type不管设置成多少都无法进行跳转

第二,在type == 2的情况下,可以实现跳转到指定的界面,但是无法获取到custom_content的参数,

         后面多次询问百度的技术支持,也没有得到解决方案。


解决:后面实在是没有办法的情况下,发现在type== 2的情况下,也就是自定义行为下,都先先调用的onNotificationClicked()方法,

          所以,就在方法中缓存参数数据,在跳转的界面获取参数。最后实现了;之前在网上看了很多的方法都没能实现;


下面是实现的具体流程



        让后台将推送的open_type设置成2,  也就是点击通知之后自定义进行跳转

        将pkg_content 设置成你指定界面的uri  , 可以在界面中通过getInten.toURI()的方法获取,然后简单的拼接一下就好

        我的是          #Intent;action=com.baidu.action.guarantee_sendtimer;category=android.intent.category.LAUNCHER;launchFlags=0x10000000;component=com.roi.wispower_tongchen/.view.activity.GuaranteeRepairedDetailActivity;end

action是自己定义的,可以任意制定,component是需要跳转的界面,其他参数可以保持不变就好;


      然后在清单文件里面配置你想要跳转的activity 如下

<!--推送测试-->
<activity android:name=".view.activity.GuaranteeRepairedDetailActivity" >
    <intent-filter>
        <action android:name="com.baidu.action.guarantee_sendtimer" />
    </intent-filter>
</activity>

这里的action要和上面的action一样


然后就在onNotificationClicked()方法中获取你想要的参数(如下)

// 获取参数并跳转到指定界面
// 自定义内容获取方式,mykeymyvalue对应通知推送时自定义内容中设置的键和值
if (!TextUtils.isEmpty(s2)) {
    JSONObject customJson = null;
    try {
        customJson = new JSONObject(s2);
        int id = 0;
        int statu = 0;
        int repairType = 0;

        if (!customJson.isNull("id")) {
            id = customJson.getInt("id");
        } if (!customJson.isNull("statu")) {
            statu = customJson.getInt("statu");
        } if (!customJson.isNull("repairType")) {
            repairType = customJson.getInt("repairType");
        }

        Constant.PUSH_ID = id;
        Constant.PUSH_STATU = statu;
        Constant.PUSH_REPAIRTYPE = repairType;

    } catch (JSONException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}

最后在activity中获取就可以了

repairCode = Constant.PUSH_ID;
statu = Constant.PUSH_STATU;
repairType = Constant.PUSH_REPAIRTYPE;

经过测试之后是可以实现的。现在还没有找到更好的解决方法





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在uni-app中,我们可以通过以下步骤实现极光推送点击通知跳转到某个页面。 第一步是引入极光推送插件,可以通过uni-app官方插件市场或者手动下载插件并导入项目中。 第二步是在App.vue文件中配置极光推送相关信息,包括appKey和masterSecret等。具体配置信息可以在极光推送的开发者后台获取。 第三步是在App.vue文件中监听极光推送点击事件,当用户点击通知时触发相应的回调函数。 第四步是在回调函数中处理点击通知的逻辑,包括获取通知的内容和参数,根据参数决定跳转到哪个页面。 具体示例代码如下所示: ``` // 在App.vue文件中监听极光推送点击事件 onShow: function() { // 监听点击通知事件 uni.$on('jpush.click', this.onJpushClick); }, // 处理点击通知的逻辑 onJpushClick: function(payload) { // 获取通知的内容和参数 var content = payload.content; var params = payload.extras; // 根据参数决定跳转到哪个页面 if (params.page === 'home') { uni.navigateTo({ url: '/pages/home/home' }); } else if (params.page === 'about') { uni.navigateTo({ url: '/pages/about/about' }); } else { // 默认跳转到首页 uni.navigateTo({ url: '/pages/home/home' }); } }, ``` 以上就是通过uni-app实现极光推送点击通知跳转到某个页面的步骤和示例代码。通过监听点击事件,我们可以在回调函数中处理逻辑,根据通知的参数跳转到相应的页面

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值