XSS终结者-CSP理论与实践

访客5年前黑客资讯703

 CSP 全称为 Content Security Policy,即内容安全战略。首要以白名单的 *** 装备可信任的内容来历,在网页中,能够使白名单中的内容正常履行(包括 *** ,CSS,Image 等等),而非白名单的内容无法正常履行,然后削减跨站脚本进犯(XSS),当然,也能够削减运营商绑架的内容注入进犯。

示例:在 HTML 的 Head 中增加如下 Meta 标签,将在契合 CSP 规范的浏览器中使非同源的 script 不被加载履行。

<meta http-equiv="Content-Security-Policy" content="script-src 'self'">

不支持 CSP 的浏览器将主动会疏忽 CSP 的信息,不会有什么影响。详细兼容性可在caniuse检查

CSP 语法组成

战略类型

CSP 有两种战略类型:

Content-Security-Policy Content-Security-Policy-Report-Only

这两种战略类型的首要差异也能够从命名上看出,之一种对不安全的资源会进行阻挠履行,而第二种只会进行数据上报,不会有实践的阻挠。
当界说多个战略的时分,浏览器会优先选用最早界说的。

指令调集

CSP 的指令是组成内容来历白名单的要害,上面两种战略类型含有以下很多指令,能够经过调配得到满意网站资源来历的白名单。

指令示例及阐明

指令 取值示例 阐明 default-src 'self' cdn.example.com 界说针对一切类型(js/image/css/web font/ajax/iframe/多媒体等)资源的默许加载战略,某类型资源假如没有独自界说战略,就运用默许。 script-src 'self' js.example.com 界说针对JavaScript的加载战略 object-src 'self' 针对,, 等标签的加载战略 style-src 'self' css.example.com 界说针对款式的加载战略 img-src 'self' image.example.com 界说针对图片的加载战略 media-src 'media.example.com' 针对或许引进的html多媒体等标签的加载战略 frame-src 'self' 针对iframe的加载战略 connect-src 'self' 针对Ajax、WebSocket等恳求的加载战略。不答应的情况下,浏览器会模仿一个状况为400的呼应 font-src font.qq.com 针对Web Font的加载战略 sandbox allow-forms allow-scripts 对恳求的资源启用sandbox report-uri /some-report-uri 告知浏览器假如恳求的资源不被战略答应时,往哪个地址提交日志信息。不阻挠任何内容,能够改用Content-Security-Policy-Report-Only头 base-uri 'self' 约束当前页面的url(CSP2) child-src 'self' 约束子窗口的源(iframe、弹窗等),替代frame-src(CSP2) form-action 'self' 约束表单能够提交到的源(CSP2) frame-ancestors 'none' 约束了当前页面能够被哪些页面以iframe,frame,object等 *** 加载(CSP2) plugin-types application/pdf 约束插件的类型(CSP2)

指令值示例及阐明

指令值 示例 阐明 * img-src * 答应任何内容 'none' img-src 'none' 不答应任何内容 'self' img-src 'self' 答应同源内容 data: img-src data: 答应data:协议(如base64编码的图片) www. *** img-src www. *** 答应加载指定域名的资源 *. *** img-src *. *** 答应加载 *** 任何子域的资源 https://img.com img-srchttps://img.com 答应加载img.com的https资源 https: img-src https: 答应加载https资源 'unsafe-inline' script-src 'unsafe-inline' 答应加载inline资源(style特点,onclick,inline js和inline css等等) 'unsafe-eval' script-src 'unsafe-eval' 答应加载动态js代码,例如eval()

[1] [2] [3]  黑客接单网

相关文章

某HR业务网站逻辑漏洞挖掘案例以及POC编写思路分享-黑客接单平台

东西预备 BurpSuiteFree (或许咱们最喜爱最常用的抓包神器,需求Java环境); 火狐浏览器(个人比较喜爱的浏览器;360/Chrome等浏览器都能够); SwitchyOmega插件(设...

怎么避免网站要害数据被人歹意收集

 昨天晚上花了几个小时用Jsoup写了一个网站收集器,帮一个高中同学收集了一个工业信息门户上的芯片待售信息。网站上显现的数据多达60w+条, 我写的程序跑了7个小时只收集了一半,算是能够交差了。 这现...

Faraday:一款多功能协同式浸透测验东西&amp;缝隙办理渠道

今日给咱们介绍的是一款名叫Fareday的东西,它是一款协同式多功能浸透测验及缝隙办理渠道。 新版本的Faraday引入了一个新的概念,即IPE(整合型浸透测验环境),也便是所谓的多用户浸透测验IDE...

如何逃逸Sysmon工具对DNS的监控-黑客接单平台

Sysmon是微软的一款轻量级的体系监控东西,最开端是由Sysinternals开发的,后来Sysinternals被微软收买,现在归于Sysinternals系列东西。它通过体系服务和驱动程序完成记...

8个增强 PHP 程序安全的函数

 安满是编程十分重要的一个方面。在任何一种编程言语中,都供给了许多的函数或许模块来保证程序的安全性。在现代网站运用中,常常要获取来自世界各地用户的输入,可是,咱们都知道“永久不能信任那些用户输入的数据...

综合利用SlickQuiz两个0-Day漏洞接管Uber的WordPress网站-黑客接单平台

本文叙述作者在参与HackerOne的H1-4420竞赛中,针对厂商Uber的某WordPress博客网站为方针,发现其内置问卷调查插件SlickQuiz最新版存在存储型XSS(CVE-2019-12...