Service Worker文件脱机事件

时间:2017-01-04 09:43:28

标签: push-notification google-cloud-messaging service-worker

谷歌Chrome最新版(v55.0.2883.87) 该(sw.js)文件中有各种事件。每次请求文件时都会发生获取事件。如何以及何时发生其他事件(同步,推送)(网络通知API)。我想调试它。有没有可用的文档?

更新 server-key-from-firebase-console

subscription-key-after-subscribing-web-notification

找到推送通知的方式 -

        String url = "https://fcm.googleapis.com/fcm/send";
        URL obj = new URL(url);
        HttpsURLConnection con = (HttpsURLConnection) obj.openConnection();

        //add reuqest header
        con.setRequestMethod("POST");
        con.setRequestProperty("Authorization", "key=<server-key-from-firebase-console>");
        con.setRequestProperty("Content-Type", "application/json");

        String urlParameters = "{\"to\":\"<subscription-key-after-subscribing-web-notification>\"}";

        // Send post request
        con.setDoOutput(true);
        DataOutputStream wr = new DataOutputStream(con.getOutputStream());
        wr.writeBytes(urlParameters);
        wr.flush();
        wr.close();

        int responseCode = con.getResponseCode();
        System.out.println("\nSending 'POST' request to URL : " + url);
        System.out.println("Post parameters : " + urlParameters);
        System.out.println("Response Code : " + responseCode);

        BufferedReader in = new BufferedReader(
                new InputStreamReader(con.getInputStream()));
        String inputLine;
        StringBuffer response = new StringBuffer();

        while ((inputLine = in.readLine()) != null) {
            response.append(inputLine);
        }
        in.close();

        //print result
        System.out.println(response.toString());

更新2: 好的,现在我发现如何从服务工作者文件中通过谷歌浏览器调试工具或从javascript启动同步事件。以下是我在Google博客post上找到的代码。

// Register your service worker:
navigator.serviceWorker.register('/sw.js');

// Then later, request a one-off sync:
navigator.serviceWorker.ready.then(function(swRegistration) {
  return swRegistration.sync.register('myFirstSync');
});

然后在/sw.js中听取事件:

self.addEventListener('sync', function(event) {
  if (event.tag == 'myFirstSync') {
    event.waitUntil(doSomeStuff());
  }
});

1 个答案:

答案 0 :(得分:0)

了解有关ServiceWorker的更多信息的一个很好的资源是MDN(Mozilla Developer Network)。

以下是与ServiceWorker相关的文档的入口点:

https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API

您有安装,获取,同步和推送事件的链接和说明。那些看起来像后台同步的新内容也会在那里记录下来。

快乐阅读。