草庐IT

安全参数

全部标签

javascript - 为什么使用 '*' 作为 postMessage 的 targetOrigin 存在安全风险?

当对postMessage()方法的targetOrigin使用通配符时,我很难理解安全问题。您调用postMessage()的窗口是否已经有一个我们要将数据发送到的来源?怎么会有人能够干涉它?使用window.location.origin将targetOrigin设置为窗口的原点是否不好?我理解在接收端检查事件源的重要性(如图here所示),但我似乎无法理解为什么发送端使用通配符作为targetOrigin是不好的当窗口已经有一个特定的原点时。 最佳答案 这本身不是风险。这只是意味着任何人都可以将您的内容嵌入到框架中并阅读您通过

javascript - 以无点风格在 Ramda 中编写无参数函数?

考虑下面的工作代码:varrandN=x=>()=>Math.floor(x*Math.random());varrand10=randN(10)times(rand10,10)//=>[6,3,7,0,9,1,7,2,6,0]randN是一个函数,它接受一个数字并返回一个RNG,当调用该RNG时,它将返回范围[0,N-1]中的一个随机整数。所以它是特定RNG的工厂。我一直在使用ramda.js,并学习函数式编程理论,我的问题是:是否可以使用ramda以无点样式重写randN?例如,我可以写:varbadAttempt=pipe(multiply(Math.random()),Math

带有对象表示法的javascript函数参数

有什么区别functionupdateSomething(item){}和functionupdateSomething({items}){}?第一个中的item变量也可以是对象,为什么第二个使用对象表示法?什么时候用前者,什么时候用后者? 最佳答案 这是来自ES2015的参数解构。在第二种情况下,您将局部变量初始化为参数的items属性的值。functionupdateSomething({items}){大致相当于functionupdateSomething(obj){varitems=obj.items;其他一些例子here

javascript - 是否可以在 vue-router 中锁定除一条以外的所有路由?安全吗?或者我应该使用另一种方法?

我想做一个在线考试,这个考试有5页,有一个倒计时计时器(120秒),每页有4个问题。120秒后,用户将自动转到下一页,或者他们可以在此之前单击下一步按钮。Laravel5.4和VueJs,用户回答的每个问题都有一个Ajax请求。我想要的是阻止用户看到其他页面。每个页面最多只能显示120秒。用户不应该能够点击后退按钮并查看之前的页面。这可能吗?我想用Vuejs和vue-router创建这个应用程序,但我不知道如何用vue-router实现它,我做了一些研究,但没有得到太多结果!或者也许我不应该使用vue-router,而是使用我自己的简单路由器,例如:$("#page1").show()

javascript - 在 Javascript 中使用 this.variable 作为默认参数有什么问题吗?

如果我有一个像这样的ES6类:classFoo{constructor(bar){this.bar=bar;}echo(value=this.bar){returnvalue;}}每次调用echo时,都应重新计算this.bar。f=newFoo(10);f.echo();>>10f.bar=99;f.echo();>>99这种用法是否会产生任何潜在问题? 最佳答案 除了常见的jsthis问题外,没有什么大问题需要担心。您可以使用调用、绑定(bind)等方法将值注入(inject)此方法。这也可能导致错误和不一致。classFoo{

javascript - 如何让 jQuery 将自定义参数传递给异步 AJAX 回调函数?

我的页面处理许多“商店”对象,每个对象都有一个名为“数据”的字段。但是,此数据是通过可能并行进行的AJAX请求获取的。functionStore(id){this.id=id;this.queryparam='blah';this.items=null;}Store.prototype.fetch=function(){$.get("/get_items",{q:this.quaryparam},function(data,status){//howtostorethereceiveddatainthisparticularstoreobject?Being//acallbackfun

javascript - 如何使用 JQuery.data() 存储 2 个参数

我有以下js:$('.overview_table_header').click(function(){header=$(this)$.get("/sort",{col:$.trim($(this).text()),sort:header.data('sort')},function(data){$('#pages').html(data.html);header.data('sort',data.sort);});});它传递2个参数(对/sort的获取请求):{"col"=>"DATA","sort"=>"OTHERDATA"}我是JQuery和Ajax的新手。如何将上述DATA和

javascript - 执行以下操作是否 100% 安全?

执行以下操作是否100%安全?varuntrusted_input_from_3rd_party='alert("xss")';document.getElementsByTagName('body')[0].appendChild(document.createTextNode(untrusted_input_from_3rd_party));考虑到第三方可以输入任何东西(HTML、CSS等),如果我通过createTextNode传递然后添加到主场? 最佳答案 这是防止XSS的好方法。通过createTextNode进行的DOM

javascript - 预定义参数

这个问题在这里已经有了答案:SetadefaultparametervalueforaJavaScriptfunction(29个答案)关闭8年前。我希望能够在JavaScript中执行此操作:functionmyFunction(one,two=1){//code}myFunction("foo","2");myFunction("bar");我试过了,还是不行。我不知道如何调用这种类型的参数,有人可以指出正确的方向吗?谢谢。

javascript - javascript eval 真的有那么大的安全威胁吗?

这个问题在这里已经有了答案:WhyisusingtheJavaScriptevalfunctionabadidea?(25个答案)关闭9年前。假设没有可用于修改某人计算机的浏览器端安全漏洞,我不明白使用eval会如何导致任何真正的威胁。谁能解释一下这是怎么可能的。有人可以在用户的​​计算机上显示某些内容,但如果不进行重定向或接受下载,就不会造成真正的伤害。不会造成服务器端损坏,对吧?