谷歌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());
}
});
答案 0 :(得分:0)
了解有关ServiceWorker的更多信息的一个很好的资源是MDN(Mozilla Developer Network)。
以下是与ServiceWorker相关的文档的入口点:
https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API
您有安装,获取,同步和推送事件的链接和说明。那些看起来像后台同步的新内容也会在那里记录下来。
快乐阅读。