uniapp对接极光推送,实现消息推送功能

devtools/2024/11/18 4:54:40/

通过集成JG-JPush和JG-JCore插件,可以在应用中添加消息推送功能,向用户发送通知、消息等。这对于提升用户体验、增加用户粘性非常有帮助‌。

效果图:

一、登录极光官网

官网链接:portalicon-default.png?t=O83Ahttps://www.jiguang.cn/console/#/home点击去创建应用

创建应用:填写应用名称和图标(填写项目名称,项目logo就行,也可填写其他的)

 选择【消息推送】服务,点击下一步

设置应用包名(图中仅为示例,最好是×××.×××.××格式),点击保存,点击下一步

 点击【推送设置】可查看android和ios的AppKey和Secret,后续需要使用

二、安装和配置uniapp极光插件 

1. 安装JPush插件

极光推送 JPush 官方 SDK - DCloud 插件市场

2. 安装JCore插件 

极光推送 JCore 官方 SDK - DCloud 插件市场

安装完后可以在我的插件里查看到购买的插件,链接:DAccount Service

3. 导入插件到项目 

4. 插件配置

打卡manifest.json的源码视图,找到 nativePlugins 节点
配置JG-JCore,设置JPUSH_APPKEY_ANDROID

三、编写代码

在App.vue中编写如下代码:(注意:极光推送信息通知回调中那个路径要改,路径就是你点击通知会打开到这个路径对应的页面) 

<script>// #ifdef APP-PLUSvar jpushModule = uni.requireNativePlugin("JG-JPush");// #endifexport default {methods: {// 通知消息getJpushModule() {// #ifdef APP-PLUS//禁止横屏plus.screen.lockOrientation("portrait-primary");//极光推送jpushModule.setLoggerEnable(true);jpushModule.initJPushService()// // 设置别名// jpushModule.setAlias({// 	alias: '',// 	sequence: 1// });this.getNotificationEnabled();//监听 极光推送连接状态jpushModule.addConnectEventListener((result) => {console.log('监听 极光推送连接状态', result);let connectEnable = result.connectEnable;uni.$emit('connectStatusChange', connectEnable);});//极光推送的消息通知回调jpushModule.addNotificationListener((result) => {jpushModule.setBadge(0);plus.runtime.setBadgeNumber(0);let notificationEventType = result.notificationEventType;// let woopId = result.extras && result.extras.dataType === 'woop' && result.extras.value;console.log('通知', result, notificationEventType);// 点击事件if (notificationEventType == 'notificationOpened') {uni.navigateTo({url: '/pages/mine-merchant/order-management/order-management'});}});uni.$on('connectStatusChange', (connectStatus) => {var connectStr = '';if (connectStatus == true) {connectStr = '已连接';this.getRegistrationID();} else {connectStr = '未连接';}console.log('监听到了连接状态变化 --- ', connectStr);});//#endif},getRegistrationID() {jpushModule.getRegistrationID((result) => {let registerID = result.registerID;console.log('获取registerID', registerID);this.setSto('registerID', registerID);});},getNotificationEnabled() {if (uni.getSystemInfoSync().platform == 'ios') {jpushModule.requestNotificationAuthorization((result) => {let status = result.status;if (status < 2) {this.noticMsgTool();}});} else {jpushModule.isNotificationEnabled((result) => {console.log('判断android是否打开权限1:true,0:false', result);if (result.code == 0) {//如果为0则表示 未打开通知权限this.noticMsgTool();}});}},noticMsgTool() {if (uni.getSystemInfoSync().platform == 'ios') {//苹果打开对应的通知栏uni.showModal({title: '通知权限开启提醒',content: '您还没有开启通知权限,无法接受到消息通知,请前往设置!',showCancel: false,confirmText: '去设置',success: function(res) {if (res.confirm) {var app = plus.ios.invoke('UIApplication', 'sharedApplication');var setting = plus.ios.invoke('NSURL', 'URLWithString:', 'app-settings:');plus.ios.invoke(app, 'openURL:', setting);plus.ios.deleteObject(setting);plus.ios.deleteObject(app);}}});} else {//android打开对应的通知栏var main = plus.android.runtimeMainActivity();var pkName = main.getPackageName();var uid = main.getApplicationInfo().plusGetAttribute('uid');uni.showModal({title: '通知权限开启提醒',content: '您还没有开启通知权限,无法接受到消息通知,请前往设置!',showCancel: false,confirmText: '去设置',success: function(res) {if (res.confirm) {var Intent = plus.android.importClass('android.content.Intent');var Build = plus.android.importClass('android.os.Build');//android 8.0引导if (Build.VERSION.SDK_INT >= 26) {var intent = new Intent('android.settings.APP_NOTIFICATION_SETTINGS');intent.putExtra('android.provider.extra.APP_PACKAGE', pkName);} else if (Build.VERSION.SDK_INT >= 21) {//android 5.0-7.0var intent = new Intent('android.settings.APP_NOTIFICATION_SETTINGS');intent.putExtra('app_package', pkName);intent.putExtra('app_uid', uid);} else {//(<21)其他--跳转到该应用管理的详情页intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);var uri = Uri.fromParts('package', mainActivity.getPackageName(), null);intent.setData(uri);}// 跳转到该应用的系统通知设置页main.startActivity(intent);}}});}},},async onLaunch() {//#ifdef APP-PLUSthis.getJpushModule();//#endif},}
</script>

四、调试运行

五、测试推送

ok,结束,手机上就会收到推送通知。


http://www.ppmy.cn/devtools/134867.html

相关文章

躺平成长-人工智能进行编程-(12)

躺平成长&#xff1a; 让每一个人在科技&#xff08;开源的网络/智能科技对于生活琐事的处理&#xff09;的帮助下&#xff0c;实现养生反卷&#xff0c;躺平成长。 开源竞争&#xff1a; 当你无法彻底掌握技术的时候&#xff0c;你就开源这个技术&#xff0c;形成技术依赖&a…

elementui el-table中给表头 el-table-column 加一个鼠标移入提示说明

前言 在使用el-table 表格中有些表格的表头需要加入一些提示&#xff0c;鼠标移入则出现提示&#xff0c;非常实用&#xff0c;我是通过el-table中的el-tooltip实现的&#xff0c;以下的效果预览 代码实现 <el-table ref"multipleTable" :data"data"…

EWM 打印

目录 1 简介 2 后台配置 3 主数据 4 业务操作 1 简介 打印即输出管理&#xff08;output management&#xff09;利用“条件表”那一套理论实现。而当打印跟 EWM 集成到一起时&#xff0c;也需要利用 PPF&#xff08;Post Processing Framework&#xff09;那一套理论。而…

蓝桥杯——数组

1、移动数组元素 package day3;import java.util.Arrays;public class Demo1 {public static void main(String[] args) {int[] arr {1,2,3,4,5,6};int k 2;int[] arr_new f(arr,k);for (int i : arr_new) {System.out.print(i",");}//或System.out.println();St…

现代密码学|古典密码学例题讲解|AES数学基础(GF(2^8)有限域上的运算问题)| AES加密算法

文章目录 古典密码凯撒密码和移位变换仿射变换例题多表代换例题 AES数学基础&#xff08;GF&#xff08;2^8&#xff09;有限域上的运算问题&#xff09;多项式表示法 | 加法 | 乘法X乘法模x的四次方1的乘法 AES加密算法初始变换字节代换行移位列混合轮密钥加子密钥&#xff08…

#渗透测试#SRC漏洞挖掘#云技术基础03之容器相关

目录 一、Podman相关 &#xff08;一&#xff09;Podman简介 &#xff08;二&#xff09;Pod相关操作 二、容器相关 &#xff08;一&#xff09;容器概念 &#xff08;二&#xff09;容器的历史发展 &#xff08;三&#xff09;Capabilities相关 三、Kubernetes&#x…

【Linux网络编程】Socket编程--TCP:echo server | 多线程远程命令执行

&#x1f308;个人主页&#xff1a; 南桥几晴秋 &#x1f308;C专栏&#xff1a; 南桥谈C &#x1f308;C语言专栏&#xff1a; C语言学习系列 &#x1f308;Linux学习专栏&#xff1a; 南桥谈Linux &#x1f308;数据结构学习专栏&#xff1a; 数据结构杂谈 &#x1f308;数据…

iOS 键盘弹出视图精准上移

1 视图精准位移&#xff0c;需要计算出输入框距离屏幕底部的距离&#xff0c;然后 计算出输入框需要上移的距离&#xff0c;就是整个视图需要上移的距离, 注意&#xff0c;我们可以自行设置一个适当的buffer,我这里是40&#xff0c;就是输入框距离 键盘有一个40的距离&#xf…