HTML5+ push消息推送

HTML5 本身并不支持直接的 push 消息推送,这通常是通过 Web 推送通知(Web Push Notifications)来实现的,需要结合服务器端的支持。以下是一个使用 Service Worker 接收和显示 push 消息的基本示例:

首先,在你的 HTML 文件中注册 Service Worker:




// 确保在 HTTPS 环境下运行
if ('serviceWorker' in navigator) {
  navigator.serviceWorker.register('/sw.js').then(function(registration) {
    // 注册成功
    console.log('Service Worker 注册成功');
  }).catch(function(err) {
    // 注册失败
    console.error('Service Worker 注册失败', err);
  });
}

然后,在 Service Worker 脚本 (sw.js) 中,你可以添加以下代码来处理 push 事件:




self.addEventListener('push', function(event) {
  if (event.data) {
    // 如果推送事件中包含数据,解析并显示
    event.waitUntil(
      event.data.json().then(function(data) {
        // 发起一个通知
        return self.registration.showNotification(data.title, {
          body: data.body,
          icon: data.icon,
          vibrate: [100, 50, 100],
          data: {
            url: data.url
          }
        });
      })
    );
  }
});
 
self.addEventListener('notificationclick', function(event) {
  // 当用户点击通知时,打开对应的 URL
  event.notification.close();
  event.waitUntil(
    clients.matchAll({ type: 'window' }).then(function(clientList) {
      // 检查是否有已经打开的窗口
      for (var i = 0; i < clientList.length; i++) {
        var client = clientList[i];
        if (client.url === '/' && 'focus' in client) {
          return client.focus();
        }
      }
      // 如果没有打开的窗口,则创建一个新的窗口
      if (clients.openWindow) {
        return clients.openWindow(event.notification.data.url);
      }
    })
  );
});

在服务器端,你需要生成一个 push 消息,并通过相应的 API 发送给用户的 Service Worker。以下是一个使用 Node.js 和 web-push 库的示例:




const webPush = require('web-push');
 
const pushSubscription = {
  endpoint: 'https://fcm.googleapis.com/fcm/send/...', // 这里填写你的端点
  keys: {
    auth: '...', // 这里填写你的认证密钥
    p256dh: '...' // 这里填写你的P-256 DH密钥
  }
};
 
const payload = JSON.stringify({
  title: 'Hello World!',
  body: '这是一条推送消息。',
  icon: '/icon.png',
  url: 'https://yourdomain.com'
});
 
webPush.sendNotification(pushSubscription, payload)
  .then(response => console.log('Push 消息发送成功', respo
最后修改于:2024年08月08日 18:31

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日