0

0

uni-app接收推送消息 uni-app如何集成UniPush

星降

星降

发布时间:2026-03-18 14:58:32

|

748人浏览过

|

来源于php中文网

原创

根本原因是uni.onPushMessage仅监听在线消息,对厂商离线推送无感;需用plus.push.addEventListener捕获系统级推送,并确保manifest.json中modulePermissions和sdkConfigs配置完整且同级。

uni-app接收推送消息 uni-app如何集成unipush

uni.onPushMessage 为什么收不到消息?

根本原因往往不是代码写错了,而是推送通道压根没通——uni.onPushMessage 只监听「在线」状态下的消息(即 App 在前台或后台但进程未被杀),它对厂商通道的离线推送完全无感。如果你测试时把 App 杀掉再发推送,这条回调永远不会触发。

实操建议:

  • 先用 plus.push.addEventListener("receive", ...)plus.push.addEventListener("click", ...) 替代,这是 5+ API 的底层监听,能捕获所有系统级推送(包括离线到达后点击/静默接收)
  • 确保在 App.vueonLaunchonShow 中都注册监听,避免冷启动时漏掉首次推送
  • 不要在页面级组件里写监听逻辑,生命周期不可靠,容易被销毁后失联
  • 安卓真机测试必须用「自定义调试基座」或「云打包 APK」,HBuilderX 默认基座的包名和证书与你 DCloud 后台配置不匹配,必然收不到

manifest.json 推送配置错在哪?

最常被忽略的是 modulePermissionssdkConfigs 两个字段缺一不可,只填 appid 是无效的。DCloud 2026 年起已强制校验完整结构,否则打包时不会注入推送模块,运行时 plus.pushundefined

正确写法示例(注意缩进和层级):

{
  "name": "MyApp",
  "appid": "__UNI__XXXXXXX",
  "description": "",
  "versionName": "1.0.0",
  "versionCode": "100",
  "transformPx": false,
  "app-plus": {
    "usingComponents": true,
    "nvueStyleCompiler": "uni-app",
    "splashscreen": {
      "alwaysShowBeforeRender": true,
      "waiting": true,
      "autoclose": true,
      "delay": 0
    }
  },
  "mp-weixin": {},
  "h5": {},
  "quickapp": {},
  "modulePermissions": ["Push"],
  "sdkConfigs": {
    "push": {
      "unipush": {
        "appid": "__UNI__XXXXXXX",
        "appkey": "your-appkey-from-dcloud-console"
      }
    }
  }
}

常见错误:

  • appid 填了,但 appkey 空着或填错 —— 它不是 AppID,而是在 DCloud 开发者中心「uni-push → uni-push 2.0」页生成的独立密钥
  • 把配置写在 app-plus 下面,而不是根级 —— manifest.json 是扁平结构,modulePermissionssdkConfigs 必须与 nameappid 同级
  • 云打包时勾选了「使用自定义 SDK」但没上传对应厂商的证书或密钥 —— 导致华为/小米等通道初始化失败,降级为个推,送达率暴跌

uniPush2 服务端怎么触发推送?

不需要自己搭后端、不用调第三方 API,uniPush2 的核心优势就是和 uniCloud 深度绑定。你只要在云函数里调用 uniCloud.callFunction 就能发,连 token 都不用管。

百灵大模型
百灵大模型

蚂蚁集团自研的多模态AI大模型系列

下载

实操路径:

  • 确保项目是「uni-app(内置 uniCloud)」模板创建的,否则云函数无法访问 uni-push 服务
  • 在云函数中使用 uniCloud.registerService('push', {...}) 初始化(官方 SDK 已内置,一般无需手动注册)
  • 真正发推送只用一行:await uniCloud.getProvider('push').send({ title: '通知标题', content: '正文', payload: '{"page":"/pages/msg/detail"}' })
  • payload 是字符串,不是对象;必须 JSON 序列化,且 key 名要小写(如 page 而非 Page),否则 H5+ 跳转会失败

注意:web 端和小程序端推送走的是 socket 在线通道,App 端才走厂商通道。所以测试时务必用真机装云打包后的 APK/iPA,否则永远看不到“通知栏弹窗”效果。

为什么厂商通道配置总失败?

不是你操作错了,是厂商平台规则变了。2026 年起,华为 HMS Core 要求应用签名 SHA-256 证书指纹必须和 DCloud 后台填写的一致;小米推送强制开启「应用内消息」开关才能下发;OPPO 则要求包名、应用名称、签名三者与 OPPO 开放平台完全一致,差一个字符都不行。

避坑清单:

  • 别信网上旧教程说的「随便填个测试密钥就行」—— 华为、小米现在全部 require 正式上架前的签名信息,开发阶段就得用最终发布签名打包,再提取指纹填入 DCloud 后台
  • 每个厂商的「AppID/AppKey/Secret」必须单独申请,不能复用其他项目的,DCloud 后台会校验绑定关系
  • 荣耀设备归入华为通道,但需额外在华为后台开通「荣耀生态」权限,否则荣耀手机收不到
  • 测试时优先用华为/小米真机,vivo 和 OPPO 对调试包限制更严,经常出现「已配置但收不到」的假阴性

最麻烦但绕不开的点:厂商通道不是配完就完事,它们有审核周期(尤其华为要 1–3 个工作日),别卡在上线前两天才去配。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python是前端还是后端
python是前端还是后端

Python属于前端也属于后端,其灵活性和丰富的生态系统使得开发人员能够在不同的领域中灵活运用。本专题为大家提供python相关的文章、下载、课程内容,供大家免费下载体验。

202

2023.08.11

前端如何实现即时通讯
前端如何实现即时通讯

实现即时通讯的方法有WebSocket、Long Polling、Server-Sent Events、WebRTC等等。详细介绍:1、WebSocket,它可以在客户端和服务器之间建立持久连接,实现实时的双向通信,前端可以使用 WebSocket API来创建WebSocket连接,并通过发送和接收消息来实现即时通讯;2、Long Polling,是一种模拟实时通信的技术等等。

275

2023.10.09

前端和后端的区别
前端和后端的区别

前端关注的是用户界面的设计和交互,而后端则注重数据处理和逻辑控制。想了解更多前端后端的相关内容,可以阅读本专题下面的文章。

413

2024.03.19

php和前端的关联介绍
php和前端的关联介绍

php既可以作为前端语言,也可以作为后端语言。想了解更多php和前端的相关内容,可以阅读本专题下面的文章。

232

2024.03.22

前端外包工作内容有哪些
前端外包工作内容有哪些

前端外包工作内容包括:1. 网站和应用程序开发;2. 用户界面和交互设计;3. 用户体验优化;4. 设计和视觉开发;5. 跨浏览器兼容性;6. 性能优化;7. 维护和更新;8. 项目管理和沟通。想了解更多前端的相关内容,可以阅读本专题下面的文章。

122

2024.05.22

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

2

2026.03.18

Java Spring Security权限控制与认证机制实战
Java Spring Security权限控制与认证机制实战

本专题围绕 Java 后端安全体系建设展开,重点讲解 Spring Security 在权限控制与认证机制中的应用实践。内容涵盖用户认证流程、权限模型设计、JWT 鉴权方案、OAuth2 集成以及接口安全防护策略。通过实际项目案例,帮助开发者构建安全可靠的后端认证体系,提升系统安全性与可扩展能力。

0

2026.03.18

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

110

2026.03.17

多环境下的 Nginx 安装、结构与运维实战
多环境下的 Nginx 安装、结构与运维实战

本专题聚焦多环境下Nginx实战,详解开发、测试及生产环境的差异化安装策略与目录结构规划。深入剖析配置模块化设计、灰度发布流程及跨环境同步机制。结合监控告警、故障排查与自动化运维工具,提供全链路管理方案,助力团队构建灵活、高可用的Nginx服务体系,从容应对复杂业务场景挑战。

13

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号