- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
类似的问题也有,但是不太清楚如何应用解决方案,一直报错。
我解释一下。我想使用服务 worker 技术创建一个简单的 html/js 应用程序。我有:
在 app.js 中的代码是(请参阅//*** 注释以明确):
// *** I receive always the error:
// *** ERROR: The path of the provided scope ('/') is not under the max scope allowed ('/js/').
// *** Adjust the scope, move the Service Worker script, or use the Service-Worker-Allowed HTTP header to allow the scope.
var headers = new Headers();
// *** I set the header in order to solve the error above:
// *** The value is set to "/" because this js is included in html file in upper folder.
// *** I tried even "../" and many more others values...
headers.append('Service-Worker-Allowed', '/');
console.log(headers.get('Service-Worker-Allowed'));
if ('serviceWorker' in navigator) {
console.log('Start trying Registrating Scope');
// *** I register the service worker.
// *** The path of service worker is "js/sw.js" because this js is included in html file in upper folder.
// *** The path of scope is "../" because is the path used by service worker, and I want it uses upper folder scope.
navigator.serviceWorker.register('js/sw.js', {scope: '../'})
.then(function(reg) {
// registration worked
console.log('Registration succeeded. Scope is ' + reg.scope);
})
.catch(function(error) {
// registration failed
console.log('Registration failed with ' + error);
});
console.log('End trying Registrating Scope');
}
正如您在评论中看到的那样,我仍然收到错误消息“提供的范围 ('/') 的路径不在允许的最大范围内 ('/js/')。调整范围,移动 Service Worker 脚本,或使用 Service-Worker-Allowed HTTP header 来允许范围。”
也许我可以移动 sw.js 文件,但我想知道哪里出了问题。当然,问题在于如何在前 3 行未注释的代码中注册 header 。
关于如何准确注册代码的任何建议?
编辑:
我缺少的是在询问 html 页面之前要设置的是请求 header ,随请求发送的 header ...我正在创建 header ,最终对 future 的新请求有用。所以 js 可能不是放置设置的正确位置......该设置必须在请求index.html之前设置,因为html或js中的设置是为响应设置的,或者为其他请求准备的
现在...
我现在的方法是调用另一个 html 页面 (register.html),在这个页面中我尝试 $.ajax() index.html 页面,并设置了正确的标题:(我现在可以用纯 js 来完成,但为了节省时间,我复制/粘贴了一些已经测试过的代码)
$(document).ready(function(){
$.ajax({
type: "GET",
beforeSend: function(request) {
request.setRequestHeader("Service-Worker-Allowed", "/");
},
url: "index.html",
complete: function () {
window.location = "index.html";
}
});
});
我希望第一次点击 ajax 调用时我可以注册 service worker,然后在 index.html 上完成重定向,我发现它已经注册了,但是这不起作用......
我重复一遍,最快的方法是将 sw.js 移动到上层文件夹中。但是有趣的是知道如何控制如何注册 service worker,尽管它在树文件夹应用程序中的位置......
其他建议...?
最佳答案
好吧......我有点困惑,即使现在我想我必须深入了解事实并更好地研究http header ......
无论如何,正如在 stackoverflow 上的许多问题和答案中所述,在 http 请求期间不可能更改 header ,除非它不是 ajax 请求(这不是这种情况)。
现在在这个帖子上 Understanding Service Worker scope对于类似的问题@Ashraf Sabry 回答说他可以使用 IIS Web 服务器的 web.config 文件更改 header 。 --> 所以最后我明白要添加的 header 是响应 header ,但在浏览器解释响应之前 --> 如此处所述https://learn.microsoft.com/en-us/iis/configuration/system.webserver/httpprotocol/customheaders/该配置用于响应 header 。
我想没有明确的方法来控制该 header 以使服务工作人员使用 html/javascript 在子文件夹中工作...这是一个只能通过服务器配置来解决的问题。
A 在 Node 上做我的测试,为了教学海豚,我尝试编写一个简单的 http 服务器来测试这个问题,从本教程开始 https://ilovecoding.org/lessons/create-a-simple-http-server-with-nodejs
结果在这里(在 Node 上运行的“server.js”文件):
var http = require('http');
var url = require('url');
var querystring = require('querystring');
var fs = require('fs');
http.createServer(function(request, response){
pathName = url.parse(request.url).pathname;
console.log(pathName);
fs.readFile(__dirname + pathName, function(err, data){
if(err){
response.writeHead(404, {'Content-type':'text/plain'});
response.write('Page Was Not Found');
response.end();
}else{
if(pathName.endsWith(".html")){
//response.writeHead(200, {'Service-Worker-Allowed':'/', 'Content-Type':'text/html'});
response.writeHead(200, {'Content-Type':'text/html'});
console.log("serving html");
}else if(pathName.endsWith(".js")){
response.writeHead(200, {'Service-Worker-Allowed':'/', 'Content-Type':'application/javascript'});
//response.writeHead(200, {'Content-Type':'text/javascript'});
console.log("serving js");
}else if(pathName.endsWith(".css")){
//response.writeHead(200, {'Service-Worker-Allowed':'/', 'Content-Type':'text/css'});
response.writeHead(200, {'Content-Type':'text/css'});
console.log("serving css");
}else{
response.writeHead(200);
console.log("serving other");
}
response.write(data);
response.end();
}
})
}).listen(8080);
使用此 js 节点服务器,我可以获得与上述链接中 IIS 中的设置相同的结果。
请注意,在使用此 js 进行一些测试后,我发现需要“Service-Worker-Allowed:/”的文件是 app.js 文件。
现在应用程序可以正常工作,不会返回任何错误。作为对 fiddler 的最终证明跟踪请求,我可以清楚地看到对 app.js 的初始请求,响应中带有“Service-Worker-Allowed:/”;
我的结论是,并非总是可以处理服务器配置,因此将 Service Worker 文件放在应用程序的根文件夹中是最好的方法。
希望这对其他人有帮助...
关于javascript - 如何准确添加 "Service-Worker-Allowed"以在上层文件夹中注册服务 worker 范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49084718/
我正在使用 choronos,它建议使用 start/stop 命令开始停止,如下所示 开始计时 停止计时 但是,我正在编写 puppet manifest,它只适用于下面的服务命令。 服务计时开始
来历及作用 services.exe进程程序文件是由微软公司为其发布的Windows操作系统定义的一个系统进程,常见于Windows 2000/XP/Vista/2007等系统中,被描述为服务和控
我一直在尝试使用installutil:installutil /u GSIS.FileMoverService.exe安装Windows服务。 我得到的输出是: Uninstalling assem
如果一个域有多个团队和多个 Web 应用程序,那么注册 Service Worker 来管理整个站点的最佳建议是什么?具有范围的顶级服务 worker /或子域中的多个服务 worker ?由于一个域
我已经在 eclipse 中创建了企业项目。动态web项目和ejb项目对企业项目有借鉴意义。当我运行管理员(企业项目)运行时选择 wildfly 服务器 18。我收到以下错误。谁能告诉我我错过了什么。
我已经使用 apache-cxf-2.7.4 创建了一个 Web 服务。我进入了我的项目中制作的类(class)。我的项目中的库是: math3-commons-3.2.jar XStream-1.4
我在域中的 Virtual Box 中运行集群计算机,默认情况下服务在 Network 服务下运行,服务一直停止,事件日志中出现以下错误。 请从下面的错误日志中查找错误详细信息。任何帮助都会很棒。 L
在我的应用程序中,用户可以在 map 上发布事件。应用程序的入口点是一个无状态的 web api 服务。为了在内部代表用户,我想要一个用户服务。我应该何时使用 Reliable Stateful Ac
当我尝试运行在WIX中创建的安装程序时,出现以下错误消息: “服务'Report Generator Service'(报告生成器服务)无法启动。请验证您是否具有启动系统服务的足够特权”。 我已经在这
尝试使用 cloudformation 创建 ECS 服务(在 Fargate 上)但出现错误: Invalid service in ARN (Service: AmazonECS; Status
我正在编写一个简单的Windows服务,该服务每个月向所有员工发送一封电子邮件。我的问题是,完成后如何停止自我?我是该领域的新手,请帮帮我。非常感谢。 它将部署在服务器上以每月运行。我没有开始做这件事
有谁知道是否有办法在 service worker 中获取此号码或日期: 将我的服务 worker 缓存命名为 cache-1182 会很方便或 cache-20171127171448 我想在安装事
我想开始使用 Azure Service Fabric 技术。 我按照this document工作并安装最新的SDK。安装后,我打开 PowerShell(“以管理员身份运行”)命令行窗口并写入这些
我在使用 whenever gem 时遇到了一些问题。我创建了一个 rake 任务,当我自己启动它时它工作得很好但是当我在日志中收到以下消息时尝试自动执行它: ActiveRecord::Statem
我想在 service fabric 集群中为两个不同的 web 应用程序(webpi/website)共享 http/80 端口,应用程序必须有 2 个不同的主机名: mywebapi.com 和
我创建了一个使用 MongoDB 实现 hibernate OGM 的应用程序。它在 Eclipse 中运行得很好,但是,当我构建一个 fat jar 并尝试运行它时,出现以下错误: Exceptio
我有一个 Selenium Python 测试套件。它开始运行,但几分钟后抛出以下错误: Exception AttributeError: "'Service' object has no attr
我按照此链接的说明进行操作:https://www.thegeekdiary.com/centos-rhel-7-how-to-make-custom-script-to-run-automatica
我在 ubuntu 下的 jboss 上部署了简单的“HelloWorld”Web 服务。 我创建了简单的客户端,但我无法让它工作。每次运行客户端时,我都会收到 NullPointerExceptio
我正在尝试为我的网站使用后台定期同步。我正在使用 localhost 并在 1*1000 毫秒时注册 periodicsync 事件,但这根本不会触发。 我看过这个demo ,但即使我将该网站安装为应
我是一名优秀的程序员,十分优秀!