uniapp 监听通知栏消息插件(支持白名单、黑名单、过滤) Ba-NotifyListener

简介(下载地址

Ba-NotifyListener 是一款实时监听通知栏消息的uniapp插件。支持白名单、黑名单;支持监听消息移除;支持自定义过滤条件(如短信验证码)等。

  • 支持监听所有通知栏消息(包含id、ticker、标题、内容、时间等等内容)
  • 支持白名单(需要监听的应用,设置后其他应用都不监听)
  • 支持黑名单(不想监听的应用,不设置白名单时有效)
  • 支持自定义内容过滤条件(如过滤短信验证码,默认过滤4~8位数字)

相关插件

应用消息通知插件(多种样式,新增支持常驻通知模式) Ba-Notify文档

应用未读角标插件 Ba-Shortcut-Badge文档

短信监听(验证码) Ba-Sms文档

截图展示

在这里插入图片描述

使用方法

script 中引入组件

	const listener = uni.requireNativePlugin('Ba-NotifyListener');

script 中调用(示例参考,可根据自己业务和调用方法自行修改)

	const listener = uni.requireNativePlugin('Ba-NotifyListener'); //本插件
	const notify = uni.requireNativePlugin('Ba-Notify'); //应用通知插件(https://ext.dcloud.net.cn/plugin?id=9231)
	export default {
		data() {
			return {
				whiteList: [ //白名单
					'com.ba.UniTemp',
					'com.tencent.mobileqq', //qq
					'com.tencent.mm', //微信
					'com.android.mms', //短信
					'com.android.incallui', //来电
				],
				blackList: [ //黑名单
					'com.ba.UniTemp',
				],
				msgList: []
			}
		},
		methods: {
			setListener(flag = 0) { //设置监听
				let params = {};
				if (flag == 1) {
					params = {
						whiteList: this.whiteList,
					    //regex: "(\\d{4,8})",正则表达式,默认为匹配4-8位的数字
					};
				} else if (flag == 2) {
					params = {
						blackList: this.blackList,
					    //regex: "(\\d{4,8})",正则表达式,默认为匹配4-8位的数字
					};
				}
				listener.setListener(params, res => {
					console.log(res);
					if (res.ok && res.data) {
						if (res.data.listenType == 1) {
							this.msgList.push('收到消息:');
							this.msgList.push(JSON.stringify(res.data));
							if (res.data.result)
								this.msgList.push("解析结果:" + res.data.result);

						}
						if (res.data.listenType == 2) {
							this.msgList.push('移除消息:');
							this.msgList.push(JSON.stringify(res.data));
						}
					}
					uni.showToast({
						title: res.msg,
						icon: "none",
						duration: 3000
					})
				});
			},
			isHasPermission() { //是否开启获取通知权限
				listener.isHasPermission(res => {
					console.log(res);
					uni.showToast({
						title: res.ok ? (res.data && res.data.isHasPermission ? '已开启' : '未开启') : res.msg,
						icon: "none",
						duration: 3000
					})
				});
			},
			openPermission() { //跳转到通知权限设置界面(仅判断未打开时跳转)
				listener.openPermission(res => {
					let msg = res.msg;
					if (res.data && res.data.isHasPermission) {
						msg = res.data.isHasPermission ? "权限打开" : "权限关闭";
					}
					uni.showToast({
						title: msg,
						icon: "none",
						duration: 3000
					})
				});
			},
			setPermission() { //跳转到通知权限设置界面(开不开都跳转)
				listener.setPermission(res => {
					console.log(res);
					let msg = res.msg;
					if (res.data && res.data.isHasPermission) {
						msg = res.data.isHasPermission ? "权限打开" : "权限关闭";
					}
					uni.showToast({
						title: msg,
						icon: "none",
						duration: 3000
					})
				});
			},
			sendNotify() {//用于测试通知
				notify.show({
						channelID: '0',
						channelName: '普通通知',
						ID: 1,
						notifyType: 0,
						ticker: 'Ticker',
						title: 'title',
						content: "【某某应用】验证码:708563。尊敬的用户,您正在...,我们不会向您索要此验证码,切勿告知他人!",
						extend: "附加参数",
					},
					(res) => {
						console.log(res)
					});
			}
		}
	}		

api 列表

方法名说明
setListener设置监听
isHasPermission是否开启获取通知权限
openPermission跳转到通知权限设置界面(仅判断未打开时跳转)
setPermission跳转到通知权限设置界面(开不开都跳转)

setListener 方法参数

设置监听

属性名类型必填默认值说明
whiteListArrayfalse‘’白名单
blackListArrayfalse‘’黑名单
regexStringfalse‘’正则表达式过滤短信内容,默认过滤4~8位数字验证码,如’(\d{4,8})’
监听通知的参数

判断 res.data 有内容(参照使用方法),监听接收到的通知

属性名类型说明
listenTypeNumber1 接收到通知 2 移除通知
packageNameString应用包名
idNumber通知 id
postTimelong时间(毫秒)
postTimeSString时间(yyyy-MM-dd HH:mm:ss 格式)
tickerTextString通知 ticker,在顶部状态栏中的提示信息
titleString通知标题
contentString通知内容
resultString通知内容根据过滤规则,解析后的结果,如短信验证码
isOngoingBoolean通知是否持续显示,侧滑不能删除
isClearableBoolean点击通知,是否自动消失

isHasPermission、openPermission、setPermission方法 返回参数

判断 res.data 有内容(参照使用方法)

属性名类型说明
isHasPermissionBoolean是否开启获取通知权限

系列插件

图片选择插件 Ba-MediaPicker文档

图片编辑插件 Ba-ImageEditor文档

文件选择插件 Ba-FilePicker文档

应用消息通知插件(多种样式,新增支持常驻通知模式) Ba-Notify文档

应用未读角标插件 Ba-Shortcut-Badge文档

应用开机自启插件 Ba-Autoboot文档

扫码原生插件(毫秒级、支持多码)Ba-Scanner-G文档

扫码原生插件 - 新(可任意自定义界面版本;支持连续扫码;支持设置扫码格式)Ba-Scanner文档

动态修改状态栏、导航栏背景色、字体颜色插件 Ba-AppBar文档

原生sqlite本地数据库管理 Ba-Sqlite文档

安卓保活插件(采用多种主流技术) Ba-KeepAlive文档

安卓快捷方式(桌面长按app图标) Ba-Shortcut文档

自定义图片水印(任意位置) Ba-Watermark文档

最接近微信的图片压缩插件 Ba-ImageCompressor文档

视频压缩、视频剪辑插件 Ba-VideoCompressor文档

动态切换应用图标、名称(如新年、国庆等) Ba-ChangeIcon文档

原生Toast弹窗提示(穿透所有界面、穿透原生;自定义颜色、图标 ) Ba-Toast文档

图片涂鸦、画笔 Ba-ImagePaint文档

pdf阅读(手势缩放、显示页数) Ba-Pdf文档

声音提示、震动提示、语音播报 Ba-Beep文档

websocket原生服务(自动重连、心跳检测) Ba-Websocket文档

短信监听(验证码) Ba-Sms文档

智能安装(自动升级) Ba-SmartUpgrade文档

监听系统广播、自定义广播 Ba-Broadcast文档

监听通知栏消息(支持白名单、黑名单、过滤) Ba-NotifyListener文档

全局置灰、哀悼置灰(可动态、同时支持nvue、vue) Ba-Gray文档

获取设备唯一标识(OAID、AAID、IMEI等) Ba-IdCode文档

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值