草庐IT

Web服务器

全部标签

javascript - 服务 worker : how to update the cache when files changed on the server?

您使用什么缓存策略?我阅读了OfflineCookbook,最简单的使用策略是缓存静态内容并忽略API调用。这个策略看起来是这样的:检查请求是否已经在缓存中如果不将请求、响应对添加到缓存返回响应如果服务器端的文件已更改,如何更新缓存?目前,客户端始终获取缓存的结果。这是我的缓存策略的代码://Youwillneedthispolyfill,atleastonChrome41andolder.importScripts("serviceworker-cache-polyfill.js");varVERSION=1;varCACHES={common:"common-cache"+VERS

javascript - 在 Google Apps 脚本中从服务器端通信到客户端

我正在尝试编写一个具有客户端和服务器端组件的GoogleApps脚本。客户端组件显示进度条。客户端调用服务器端函数(异步调用),其进度必须显示在客户端进度条中。现在,我想要的是能够根据服务器端功能的反馈更新客户端进度条。这可能吗?由于JS异步进行服务器端调用这一事实造成了复杂性,因此我无法真正在客户端调用函数和更新进度条的循环。我当然可以将服务器端函数的执行分成多个步骤,从客户端一个一个地调用,每次更新状态栏。但我想知道是否有更好的解决方案。有没有办法从服务器端调用客户端函数,并根据传递的参数更新进度条?或者有没有办法从服务器端访问客户端进度条对象并修改它?

javascript - Angular 使用根作用域与服务来共享数据

我一直在读wroxangularbook.在书中作者描述了一种在Controller之间共享数据的方法是在根范围内拥有一个属性更新根作用域的属性广播属性已更新的事实所有需要知道的子作用域,都会收听广播。而不是在服务上公开一个对象,让Angular的双向数据绑定(bind)完成所有繁重的工作。为什么有人会采用“根范围发布/订阅”方法,而不是在服务上公开对象? 最佳答案 这个问题很有趣。首先我们应该考虑各个层面的差异:范围对于$rootScope,我们在全局范围内定义变量在共享服务的情况下,我们可以将此服务注入(inject)真正使用此

javascript - 刷新服务 worker 中使用 importScripts 导入的脚本

我有一个网站,其中有一个serviceworker,例如://ImportascriptfromanotherdomainimportScripts('https://example.com/script.js')假设script.js更新了一些新代码,并且由于推送事件激活了serviceworker(用户在此期间没有再次访问我的网站)。importScripts是在每次激活serviceworker时检查更新,还是在首次安装serviceworker时只下载一次script.js?有什么方法可以让服务worker每次收到推送消息时刷新服务worker代码(尤其是导入的脚本)?

javascript - angular2-in-memory-web-api 404 错误

我正在尝试按照本指南以Angular2构建5分钟的应用程序:https://angular.io/docs/ts/latest/tutorial/toh-pt6.html.在http部分,我添加了一个假服务器,但我收到404错误,因为angular2-in-memory-web-api.http://localhost:4200/vendor/angular2-in-memory-web-api/in-memory-backend.service.jsFailedtoloadresource:theserverrespondedwithastatusof404(NotFound)我试图

javascript - 等到 Webpack 开发服务器准备就绪

要求我需要运行webpack-dev-server并等待服务器准备好提供页面。解决方案//Startawebpack-dev-servernewWebpackDevServer(webpack(myConfig),{publicPath:myConfig.output.publicPath,hot:true,historyApiFallback:true,//Itsuppresserrorshowninconsole,soithastobesettofalse.quiet:false,//Itsuppresseverythingexcepterror,soithastobesettof

javascript - 尝试通过 Web API 创建记录时出现“未声明的属性”

我收到一个我似乎无法调试的错误。我正在尝试通过自定义HTML/JavaScript网络资源创建自定义事件实体。用户点击一个按钮和以下参数:varparams={'rob_faqid@odata.bind':'/rob_faqs(guid-here)','rob_source':180840000,'subject':'Signpost','actualstart':newDate(),'actualend':newDate()};被传递到这个URL:https://dynamicsorg/api/data/v8.2/rob_quickactions/具有以下header:xhr.set

javascript - 您可以为 Web Worker 指定名称吗?

如果您启动两个使用相同JavaScript文件的WebWorker,Firefox无法在about:debugging#workers中区分它们。您会得到两个相同的条目(列在“其他worker”下)。为了调试,为webworker分配名称会很方便。例如,在Java中有Thread#setName.JavaScript的网络workerAPI中是否有等效的东西? 最佳答案 Worker()constructor接受一个可选的选项参数,它可以包含一个名称属性,例如:letworkerOne=newWorker(URL,{'name':'

javascript - 来自服务器数据的 Vue2 路由器链接

我有一个Vue2SPA页面,它正在从服务器加载内容。客户可以在CMS中对其进行编辑。当用户添加相对链接(比如说/about-us)时,Vue应该选择它并将其视为菜单链接(已经有/about-us链接)。但是在内容中添加的/about-us链接会重新加载整个页面,因此它不会被选为vue路由。如何将路由器附加到此类链接?到目前为止,我所做的是更改后端响应中的内容。所以我本质上是在改变Text进入Text使用:functionparseVueLinks($value){$pattern="/]*)href=\\\"[^http|https|mailto|tel]([^\\\"]*)\"([^

javascript - 将 WMD 编辑器的预览 HTML 与服务器端 HTML 验证对齐(例如,没有嵌入的 JavaScript 代码)

关于如何对WMD编辑器生成的Markdown进行服务器端清理以确保生成的HTML不包含恶意脚本,如下所示:但我也没有找到堵住客户端漏洞的好方法。当然,客户端验证不能替代服务器上的清理验证,因为任何人都可以假装是客户端并向您发送令人讨厌的Markdown。而且,如果您在服务器上删除HTML,攻击者将无法保存错误的HTML,这样其他人以后就无法看到它,并且他们的cookie被盗或session被错误的脚本劫持。因此,有一个有效的案例表明,在WMD预览Pane中执行无脚本规则可能也不值得。但想象一下,攻击者找到了一种将恶意Markdown放到服务器上的方法(例如,来自另一个站点的受损提要,或