首页
学习
活动
专区
圈层
工具
发布

安全研究 | 由postMessage导致Facebook账户劫持的DOM XSS

第二个漏洞与第一个漏洞相关,其影响为可以构造不安全的脚本形成XSS,或者基于接收数据通过Eventlistener方式提交表单。...在我测试该POST请求的发生源时,我发现该过程的iframe页面中还会加载页面‘https://www.facebook.com/platform/page_proxy/?...如果有消息进来且满足所有条件,它会基于消息中包含的数据设置相应属性,并随之提交一个表单。...有意思的是其表单构造方法为submitForm,其会把表单中的action属性直接设置为消息中收到的“a.data.params.appTabUrl”。...如果其’appTabUrl’的URL链接以http/https开头,则后台不会对该URL进行安全验证,因此,我们可以在此引入JS等其它形式触发XSS!

1.3K10

安全研究 | Facebook中基于DOM的XSS漏洞利用分析

存在漏洞的终端节点将接收请求参数中用户可控制的内容,并使用postMessage中的发送消息来构建一个数据对象,该对象将与postMessage一起发送到已打开的窗口。...接下来,我们所发现的第二个漏洞跟第一个漏洞有关,攻击者可以利用这个漏洞来根据Eventlistener接收到的表单提交数据来构造一个不安全的脚本。...通过跟踪请求源,我发现这个页面同样加载了iframe中的https://www.facebook.com/platform/page_proxy/?...其次,它将设置一个EventListener并等待接收消息。如果收到了一条满足所有条件的消息,它将在根据消息中的数据设置其属性之后提交一个form表单。...URL中的“appTabUrl”字符串中的URL没有检查是否以http/https开头,因此我们就可以使用JavaScript来实现利用XSS漏洞了。

1.2K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    AJAX如何向服务器发送请求?

    它通过在后台发送请求并异步地获取响应,实现了与服务器进行数据交互而不需要刷新整个页面。传统上,在Web应用程序中与服务器进行交互,需要通过提交表单或点击链接来触发页面跳转或刷新。...更新页面内容:根据服务器响应的数据,可以使用JavaScript代码来更新页面的部分内容,从而实现动态加载和更新数据。使用AJAX发送GET请求对于简单的数据获取和展示,一般使用GET请求。...然后,通过open()方法设置请求类型为GET,URL为"data.php",并通过send()方法发送请求。在服务器返回响应时,回调函数会被触发。...表单提交与验证:在表单提交时,使用AJAX可以实现异步验证用户输入的数据,并在页面中实时反馈验证结果,提高用户体验。同时,也可以通过AJAX以异步方式将表单数据发送到服务器进行处理。...购物车更新:在电商网站中,用户将商品添加到购物车中时,可以通过AJAX将商品信息发送到服务器,实现购物车的实时更新和交互。

    2.4K30

    JavaScript学习笔记(五)——Ajax

    GET和POST模式: GET方式一般用来传送简单数据,大小限制在1kb以下,请求的数据被转化成查询字符串并追加到请求的URL之后发送; POST可以达到2MB,他是将数据存放在send方法中发送,在数据发送之前必须先设置...serialize()序列化表单 在jQuery中,可以使用serialize函数将表单数据序列化为键值对,创建url编码文本字符串进行提交。...Ajax中的全局事件 ajax的全局事件会在调用其他事件的时候默认触发: ajaxStart() ajaxSend() ajaxSuccess() ajaxComplete() ajaxStop() ajaxError...此方法大大简化了使用ajax提交表单时的数据传递问题,不需要逐个地以JavaScript的方式获取每个表单属性的值。...ajaxSubmit() 适用于以事件机制提交表单,如通过超链接、图片的click事件等提交表单。使用时只需要指定表单的action属性即可,不需要提供submit按钮。

    2.8K10

    JavaScript 编程精解 中文第三版 十八、HTTP 和表单

    如果我们将本例 HTML 表单中的method属性更改为POST,则浏览器会使用POST方法发送该表单,并将请求字符串放到请求正文中,而不是添加到 URL 中。...但这样不带表单的字段不能被提交(一个完整的表单才可以),当需要和 JavaScript 进行响应时,我们通常也不希望按常规的方式提交表单。...在一个form拥有焦点时,点击enter键也会有同样的效果。 通常在提交一个表单时,浏览器会将页面导航到form的action属性指明的页面,使用GET或POST请求。...change事件不会在每次有输入时都被调用,而是在内容在改变并失焦后触发。为了及时的响应文本字段的改变,则需要为input事件注册一个处理器,每当用户有输入或更改时就被触发。...当一个表单被提交时,会触发其submit事件,JavaScript 处理器可以通过调用preventDefault来禁用默认的提交事件。表单字段的元素不一定需要被包装在标签中。

    5.2K20

    表单脚本

    下述内存主要讲述了《JavaScript高级程序设计(第3版)》第14章关于“表单脚本”。 刚开始人们使用JavaScript,最主要的目的之一就是表单的验证,分担服务器处理表单的责任。...一、表单的基础知识 在HTML中,表单由元素来表示,而在JavaScript中,表单对应的则是HTMLFormElement类型。...method 要发送的HTTP请求类型;等价于HTML的method特性 name 表单的名称;等价于HTML的name特性 reset() 将所有表单域重置为默认值 submit() 提交表单 target...(textarea除外,在文本区中回车会换行)。如果表单没有提交按钮,安回车键不会提交表单。 注意,通过上述方式提交表单,浏览器会在将请求发送给服务器之前触发submit事件。...,请参考【HTML防止input回车提交表单】 (2)JavaScript中提交 var form = document.forms[0]; form.submit(); 注意,这种方式不会触发sumbit

    6.4K41

    Github 移除 JQuery 的过程

    最重要的是,使用jQuery在一个浏览器中构建的JavaScript特性通常也可以在其他浏览器中工作。...实现CSS类名切换; CSS现在支持在样式表而不是JavaScript中定义可视化动画; $.ajax请求可以使用Fetch标准执行; addEventListener()接口足够稳定,可以跨平台使用;...大量与rails行为接口的旧代码,我们的Ruby on rails适配器采用“不引人注目”的JS方式,将AJAX生命周期处理程序附加到某些表单: 我们不必一次将所有这些调用站点重写为新方法,而是选择触发假...ajax*生命周期事件,并让这些表单像以前一样异步提交其内容;只有这次fetch()在内部使用。...因此,即使那些使用JS增强的web表单和其他UI元素通常也会在浏览器中禁用JavaScript。在某些情况下,我们能够完全删除某些遗留行为,而不必在vanilla JS中重写它们。

    2.9K10

    JavaScript之Ajax异步

    一.GET与POST 在提供服务器请求的过程中,有两种方式,分别是:GET和POST。在Ajax使用的过程中,GET的使用频率要比POST高。...'MyHeader', 'Lee'); //放在open方法之后,send方法之前 PS:我们只可以获取服务器返回回来响应头信息,无法获取向服务器提交的请求头信息,自然自定义的请求头,在JavaScript...GET请求 GET请求是最常见的请求类型,最常用于向服务器查询某些信息。必要时,可以将查询字符串参数追加到URL的末尾,以便提交给服务器。 xhr.open('get', 'demo.php?...POST请求 POST请求可以包含非常多的数据,我们在使用表单提交的时候,很多就是使用的POST传输方式。...因为POST请求和Web表单提交是不同的,需要使用XHR来模仿表单提交。

    1.5K00

    Tekton Trigger 的使用

    前面我们使用 Tekton 都是通过手动创建一个 TaskRun 或者一个 PipelineRun 对象来触发任务。...但是在实际的工作中更多的是开发人员提交代码过后来触发任务,这个时候就需要用到 Tekton 里面的 Triggers 了。...首先我们需要完成触发器的配置,当我们提交源代码到 GitLab 的时候,需要触发 Tekton 的任务运行。所以首先需要完成这个触发器。...这样我们就可以在 TriggerTemplate 对象中通过参数来读取上面 TriggerBinding 中定义的参数值了,定义一个如下所示的 TriggerTemplate 对象,声明一个 TaskRun...,这个时候在 Kubernetes 集群中就会出现如下所示的任务 Pod: $ kubectl get pod -l triggers.tekton.dev/eventlistener=gitlab-listener

    2.8K20

    30分钟全面解析-图解AJAX原理

    一、什么是 AJAX  1.为什么需要AJAX 当需要从服务器获取数据,并刷新页面的操作,如果不采用AJAX,则需要用提交整个表单的方式,当提交表单时,发送请求给服务器,页面需要等待服务器发送完response...看下面的例子:   当我们切换DropDownList中的Item时,JavaScript发送异步请求给Server端,Server端返回数据,然后JavaScript将数据解析出来,拼接了一个Table...在传输过程中,我们可以看下HTTP Headers。 三、AJAX提交请求和服务响应的原理 1.代码 客户端HTML代码: 在传输过程中,我们可以看下HTTP Headers: 7.AJAX  GET和POST方式区别 AJAX发送请求和POST发送请求的代码如下: //GET方式 function testGet() {...发送的信息存放在content中 4.Post方式需要指定Request Header的类型。Get方式不需要指定。 5.GET方式将参数暴露在URL中,POST不暴露。

    4.3K121

    【Vue.js】监听器功能(EventListener)的实际应用【合集】

    在实际开发过程中,我遇到了一个颇为棘手的小问题 为了让代码结构更为清晰,便于后续的维护与管理工作,我打算把 HTML 文件中 标签内的 JavaScript 代码迁移到外部的...解决方法阐述 为有效化解这一困境,我采用了在 JS 文件中监听 DOMContentLoaded 事件的策略。此事件是在浏览器完成解析 HTML 文档且所有 DOM 元素构建完毕后触发的关键信号。...相关知识总结: EventListener(事件监听器)是 JavaScript 中的一个重要概念,用于监听和响应 HTML 文档中的事件。...EventListener可以让你指定一个函数,当特定事件发生时就会调用这个函数。 使用方法 添加监听器:通过addEventListener方法来为元素添加事件监听器。...实际应用场景 用户交互响应:如上述按钮点击的例子,通过监听器可以响应用户操作,改变网页内容、提交表单或者执行其他复杂的逻辑。

    64710

    什么是jQuery?

    web页面时触发,可以写多次ready事件,不会后者覆盖前者,依次从上向下执行,我们常用$(函数)简化 ready和onload同时存在时,二者都会触发执行,ready快于onload change:当内容改变时触发...focus:焦点获取 select:选中所有的文本值 keyup/keydown/keypress:演示在IE和Firefox中获取event对象的不同 mousemove:在指定区域中不断移动触发...mouseover:鼠标移入时触发 mouseout:鼠标移出时触发 submit:在提交表单时触发,true表示提交到后台,false表示不提交到后台 click:单击触发 dblclick:双击触发...最后一个是对表单的数据进行封装,将表单的数据封装成JSON格式 `load()` 首先,我们来使用一下load()这个方法吧。在文档中对它的解释是这样子的。 ?...于是乎,Jquery也提供了serialize()这么一个方法,给我们自动把表单中的数据封装成JSON格式的数据 使用之前要注意的是: 为每个jQuery对象设置一个name属性,因为name属性会被认为请求参数名

    4K70

    JavaScript(十三)

    表单的基础知识 ---- 在 HTML 中,表单是由 form 元素来表示的,而在 JavaScript 中,表单对应的则是 HTMLFormElement 类型。...enctype: 请求的编码类型,等价于 HTML 中的 enctype 特性 length: 表单中控件的数量 method: 要发送的 HTTP 请求类型,通常是 “get” 或 “post”,等价于...HTML 的 method 特性 submit(): 提交表单 reset(): 将所有表单域重置为默认值 提交表单 使用 input 或 button 都可以定义提交按钮,只要将其 type 特性的值设置为...用户单击重置按钮重置表单时,会触发 reset 事件,利用这个机会,我们可以在必要时取消重置操作。 表单字段 可以像访问页面中的其他元素一样,使用原生 DOM 方法访问表单元素。...value 值改变时触发,对于 select 元素,在其选项改变时触发 文本框脚本 ---- 在 HTML中,有两种方式来表现文本框: 使用 input 元素的单行文本框 使用 textarea 元素的多行文本框

    5.4K20

    Django之json、Ajax简介及实例介绍

    整个过程中页面没有刷新,只是局部刷新了; 在请求发出后,浏览器不用等待服务器响应结果就可以进行其他操作; AJAX的优缺点 优点: AJAX使用Javascript技术向服务器发送异步请求;...页面中给出注册表单; 在username表单字段中添加onblur事件,调用send()方法; send()方法获取username表单字段的内容,向服务器发送异步请求,参数为username; django...,将表单内容编码为用于提交的字符串。...该函数不会序列化不需要提交的表单控件,这和常规的表单提交行为是一致的。...例如:不在标签内的表单控件不会被提交、没有name属性的表单控件不会被提交、带有disabled属性的表单控件不会被提交、没有被选中的表单控件不会被提交。

    7.7K20

    杨老师课堂之Jquery的筛选,事件,效果,Ajax,javascript跨域)

    可以用同样的方法解决 元素上的问题 阻止默认行为 网页中的元素都有自己默认的行为,例如:单击超链接后悔跳转,单击”提交”按钮会表单会提交,有时需要阻止元素的默认行为 在jquery中,提供了preventDefault...举一个例子,在项目中,经常需要验证表单,在单击”提交”按钮是,验证表单内容,例如元素是否是必填字段,某元素长度是否够6位,单表单不符合提交条件时,要阻止表单的提交 eg: $(“#sub”).bind(...jQuery.getScript(url, [callback]),通过 HTTP GET 请求载入并执行一个 JavaScript 文件。...•页面初次加载时不需要加载全部的javascript文件,在需要时动态加载 jQuery.getJSON(url, [data], [callback]) 通过 HTTP GET 请求载入 JSON...跨域:在一个服务器上,去访问另一个服务器 jQuery如何实现跨域请求?使用JSONP形式实现跨域。 javascript如果调用另一个域程序,不能执行当前域js函数。

    10.2K20

    【线上缺陷】前端重复提交的产生原因和预防措施

    o 前端状态未正确重置(如请求失败后,“提交中” 状态未解除,或禁用的按钮未恢复,可能迫使用户刷新页面后再次提交,导致重复)。 2....o 重复请求未被拦截:如前端未使用防抖、节流或 Token 机制,导致同一请求被多次发送(尤其在高频操作场景下)。 3....o 多标签页 / 窗口:在多标签页中打开同一表单页面,分别提交可能导致重复请求(尤其当页面未做跨标签状态同步时)。 三、业务逻辑设计的疏忽 1....如何规避 在软件防呆设计中,规避前端意外重复点击提交按钮(如表单提交、订单确认等场景)是常见需求,核心目标是防止重复触发请求(如重复提交数据、重复下单),同时保证用户体验。...页面加载时,前端从后端获取一个唯一的token(如 UUID),存储在表单或本地(如localStorage、隐藏字段)。 2. 点击提交时,将token随请求一起发送给后端。 3.

    35310

    XSS 和 CSRF 攻击

    浏览器将禁止页面的Javascript访问带有HttpOnly属性的Cookie。 目前主流浏览器都支持,HttpOnly解决是XSS后的Cookie支持攻击。 比如php代码的使用 在PHP中,可以使用$_GET和$_POST分别获取GET请求和POST请求的数据。在JAVA中,用于获取请求数据request一样存在不能区分GET请求数据和POST数据的问题。 ...2.验证码 另外一个解决这类问题的思路则是在用户提交的每一个表单中使用一个随机验证码,让用户在文本框中填写图片上的随机字符串,并且在提交表单后对其进行检测。...> 我们可以看到,这个函数调用了gen_stoken()函数并且生成在WEB表单中包含隐藏域的HTML代码。 接下来让我们来看实现对隐藏域中提交的Session令牌的检测的函数: 这个函数检测了$_SESSION[STOKEN_NAME]和$_REQUEST[FTOKEN_NAME]的存在性(我使用了$ _REQUEST方法来使得GET和POST两种方式提交的表单变量均能够被接受

    1.5K10
    领券