草庐IT

安全开发

全部标签

javascript - .textContent 是否完全安全?

我正在执行element.textContent=unescapedData以将未转义的用户输入放在网站上。攻击者有什么办法可以利用它来做坏事吗?如果它有以下CSS吗?max-width:30rem;max-height:3rem;overflow:hidden;我考虑过使用奇怪或无效的Unicode字符,但找不到有关如何实现此目的的任何信息。 最佳答案 相关规范似乎在https://dom.spec.whatwg.org/#dom-node-textcontent.假设element是一个Element或DocumentFragm

javascript - 与 AMD (requirejs) 一起获得闭包编译器类型安全性的最可靠方法是什么?

虽然JavaScript及其许多库(jQuery、RequireJS)允许创建许多很棒的网站,但在考虑构建更大的网站时,我发现它缺乏类型安全性令人望而生畏。Google有一个很棒的closurecompiler这让你可以annotate你的JavaScript和JSDoc并检查它的类型。在试用了其丰富的类型系统后,我预计这将大大提高生命周期更长的JavaScript项目的可维护性。唯一的问题是它不能很好地与AMD一起玩像RequireJS这样的库。有一个实验--transform_amd_modules连接JavaScript文件并通过消除它来处理作用域的标志。然而,这似乎有点反模式,

javascript - 将 'arguments' 传递给 'apply()' 是否安全

假设我有以下代码(完全没用,我知道)functionadd(a,b,c,d){alert(a+b+c+d);}functionproxy(){add.apply(window,arguments);}proxy(1,2,3,4);基本上,我们知道apply需要一个数组作为第二个参数,但我们也知道arguments不是一个正确的数组。代码按预期工作,所以可以肯定地说我可以将任何类似数组的对象作为apply()中的第二个参数传递吗?以下内容也可以使用(至少在Chrome中):functionproxy(){add.apply(window,{0:arguments[0],1:argumen

javascript - Chrome 开发工具 : view all event listeners used in the page

chrome开发工具(或任何扩展)中是否有一个功能,我可以通过它查看某个页面/应用程序上使用的所有事件监听器。编辑:它肯定不是这个问题的重复:HowdoIvieweventsfiredonanelementinChromeDevTools?上述问题解释了如何查找在我们与我们的应用交互时触发的特定事件(我知道如何做到这一点!)。我正在寻找的是我们在应用程序中监听的所有事件的列表以及它们附加到哪些DOM元素。 最佳答案 ChromeDevtool无法为您完成此操作。但是您可以使用chrome提供的API检查控制台中的那些:getEven

javascript - 依赖 Content-Type : text/plain to mitigate malicious javascript execution in response? 是否安全

我们有一个返回的web应用程序HTTP/1.1400BadRequest...Content-Type:text/plain;charset=UTF-8Content-Length:57Date:Tue,14Apr201519:24:54GMTConnection:closeInvalidprojectareaitemidalert(1086)据我了解,依靠Content-Type:text/plain;charset=UTF-8作为防御来阻止javascript执行是不够的。相反,应该对输出进行编码,并且应该对输入进行输入验证并丢弃垃圾。我正在寻找的是关于处理具有javascript

javascript - Chrome 开发者工具中 JavaScript 的奇怪行为

最近,在开发者工具中使用JavaScript时,我发现了一个奇怪的功能。Chrome接受带运算符(加号、减号)的左括号和带右括号的运算符之间的任何代码并执行它,如下所示:我没有在其他浏览器中发现这种行为,只是在Chrome中。也许这是一个特性,但为什么以及如何工作,它会不会是JavaScript引擎的问题? 最佳答案 这是chrome评估您的输入的方式:with(typeof__commandLineAPI!=='undefined'?__commandLineAPI:{__proto__:null}){//yourcodehere

javascript - AJAX 跨域安全背后的基本原理是什么?

考虑到编写跨域获取数据的服务器端代理的简单性,我不知道阻止客户端AJAX跨域调用的最初意图是什么。我不是在寻求猜测,我是在寻找语言设计者(或与他们关系密切的人)的文档,了解他们认为自己在做什么,而不仅仅是给开发人员带来轻微的不便。TIA 最佳答案 防止浏览器充当反向代理。假设您正在浏览http://www.evil.com从您办公室的PC上,并假设该办公室中存在一个包含敏感信息的内部网http://intranet.company.com只能从本地网络访问。如果跨域策略不存在,www.evil.com可以向http://intran

javascript - Web Workers 是一种安全的方式来沙盒不受信任的 JavaScript 代码吗

我想知道WebWorker是否是对不受信任的JavaScript代码进行沙盒处理的安全方法。例如,在绘图应用程序的上下文中,开发人员可以在其中实现新的绘图工具,您可以将他们的代码放入webworker中,并且每当用户单击Canvas时,向他们发送包含光标位置的JSON消息,以及图像数据数组,当脚本完成时,它会传回一条包含新图像数据的消息。这是否安全,或者是否存在我没​​有想到的风险? 最佳答案 DOM对Webworker不可用,但可以访问同源内容,例如indexedDB。请参阅我的相关问题:Canworkersbesecureeno

javascript - Microsoft Edge 不接受内容安全策略的哈希

问题Content-Security-Policy应该默认将脚本和样式解析列入黑名单,并允许它基于各种指令来验证预期输出的哈希值。浏览器必须无法实现任何未预先提供匹配哈希的Javascript或CSS。具有匹配散列的代码应正常执行。MicrosoftEdge拒绝所有JS/CSS页内block。说明在MicrosoftEdge和任何其他浏览器中访问下面的实时演示链接。现场演示:http://output.jsbin.com/biqidoqebu演示原始源码#loading{color:transparent}#loading:after{color:green;content:"Styl

javascript - 在开始 Ember.js 时,Rails 或服务器端开发人员应该进行哪些思维范式转变?

虽然我最近的大部分工作主要是使用RubyonRails和大量的Javascript(主要是jQuery),但我想构建一个单页应用程序并意识到Ember.js似乎是一个崭露头Angular的流行框架用于接近此类应用程序。从各种来源的文档和教程来看,与RubyonRails或其他典型的服务器端框架相比,Ember.js似乎需要一种非常不同的思考方式来解决问题。随着时间的推移,人们使用诸如RubyonRails之类的框架发展起来的关于“事物应该工作的方式”的某些假设甚至可能妨碍真正理解和接受“Ember方式”。RubyonRails开发人员在尝试学习Ember时需要消除哪些先入为主的观念?R