草庐IT

线程安全——Synchronized

全部标签

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——仅获取正则表达式匹配的可变部分

给出:varregexp=newRegExp("","g");在javascript中,将变量分配给与.*匹配的任何内容的最简单方法是什么?我可以这样做,但是有点难看:myString.match(regexp).replace("",""); 最佳答案 JavaScript应该在正则表达式匹配时返回一个数组对象,其中数组的零索引是匹配的整个字符串,后面的索引是捕获组。在您的情况下,类似于:varmyVar=regexp.exec(myString)[1];应将(.*?)捕获组的值分配给myVar。

javascript - 在javascript中加入多个回调/线程?

我正在寻找Thread.Join()类型的东西。假设我在javascript中触发了4个事件。我想执行代码,但只有在所有4个回调都完成之后。我怎么做?我能想到的唯一方法是检查4个回调是否正在通过全局变量进行处理,在这种情况下我忽略或抛出异常。但否则在每个回调中执行类似globalVar++的操作,并在每个回调结束时调用IsItDone()以检查globalVar是否==4。但是..我有点不喜欢它,尤其是因为我需要使用全局变量。 最佳答案 您可以自己建立一个队列并包装回调,但这有点麻烦。幸运的是,有大量的图书馆可以提供帮助。我不喜欢计

javascript - JQuery 选择器问题——如何找到目标 = _blank 的所有 HREF?

我的“JQuerySelectorFoo”很臭。我需要找到目标属性为_blank的所有HREF,并将它们替换为通用窗口/目标。非常感谢您的帮助! 最佳答案 $("a[target='_blank']").attr('target','sometarget');你是说类似的意思吗? 关于javascript-JQuery选择器问题——如何找到目标=_blank的所有HREF?,我们在StackOverflow上找到一个类似的问题: https://stackov

javascript - 包裹在 pre 标签中的 Json 结果——如何获取它的值(value)

这是我第一次使用json。我正在尝试从我的操作方法中返回Json:publicJsonResultUpload(){...returnJson(new{foo="sos....sos....sos..."});}但结果我得到的只是我的消息包装在这个“pre”标签中。如何从中解析“foo”?"{"foo":"sos....sos....sos..."}" 最佳答案 我认为您收到包含在pre标记中的数据的原因是因为您请求的数据是HTML而不是纯文本或json。尝试将数据类型指定为json以停止将响应转换为HTML。

IE6 中的 JavaScript 多线程?

JavaScript多线程在IE6中是否可行?是否有任何第三方库? 最佳答案 JavaScriptdoesnotsupportnativemultithreading在当前的网络浏览器中。即使支持,我敢打赌IE6也不会支持它:)在多个iframe中运行脚本可能是一种解决方法,如JasonKestersuggestedinanotheranswer.此外,对于现代浏览器,您可能有兴趣查看WebWorkers,但这绝对是IE6联盟之外的东西:StackOverflow:JavaScriptandThreadsDiveintoHTML5:

javascript - 使用正则表达式验证字符串是否是 URL 安全的

我有一个网站,用户可以在其中选择用户名。目前,他们几乎可以输入任何字符,包括@!#等等我知道我可以使用正则表达式,这可能就是我要选择的。我将使用一个否定集,我假设它是正确的工具:[^@!#]那么,我怎样才能知道要放入那个集合中的所有非法字符呢?我可以开始手动放入那些显而易见的东西,例如!@#$%^&*(),但是有没有一种简单的方法可以做到这一点而无需手动将它们中的每一个都放入?我知道很多网站只允许包含字母、数字、破折号或下划线的字符串。类似的东西对我来说很管用。如有任何帮助,我们将不胜感激。谢谢S.O.! 最佳答案 不使用否定,只将

javascript - 在 Javascript 中用 if 语句包装 For in 循环——遍历数组

JSLint一直提示这样的事情varmyArray=[1,2,3];for(varvalueinmyArray){//BLAH}说我应该把它包装在一个if语句中。我知道如果要遍历对象的属性,则需要将其包装起来,但在这里我应该在if语句中放入什么才能进行正确的过滤。此外,当我做类似的事情时for(vari=0;i它提示说我已经被定义了。除了使用不同的变量名外,我该如何防止这种情况发生? 最佳答案 JSLint提示了很多其实并不有害。在这种情况下,提示for...in是正确的,因为这是遍历数组的错误构造。这是因为您不仅会获得数字键,还会