Web 安全之 Permissions Policy(权限计谋)详解
什么是 Permissions Policy(权限计谋)?Permissions Policy 为 web
开发人员提供了明白声明哪些功能可以在网站上利用,哪些功能不能在网站上利用的机制。可以设置一组计谋,用于限制站点代码可以访问的 API
大概修改欣赏器对某些特性的默认行为。设置 Permissions-Policy 可以在代码库不断演进的同时强制执行最佳实践,同时更安全地组合第三方内容。
Permissions Policy 类似于 Content Security Policy(CSP 内容安全计谋),但控制的是功能特性,而不是安全行为。
Permissions Policy 从前被称为 Feature Policy,名称已更改了,HTTP header 的语法也随着更改了,以是如果从前利用了
Feature Policy,需要检查下欣赏器的支持情况, 语法保持稳定。
Permissions Policy 用途
首先看几个可以利用 Permissions Policy 的场景:
[*]开发者可以限制或克制对某些敏感 API 的利用,如摄像头、麦克风、地理位置等,有助于保护用户的隐私,防止恶意网站滥用这些 API 收集用户的个人信息。
[*]可以限制对某些功能强大但存在潜在风险的 API 的访问权限,如iframe、Service Worker、Notification等,可以减少恶意攻击和跨站点脚本等网络安全威胁。
[*]可以用于改善用户体验,例如通过禁用一些音视频自动播放或弹出式广告等,减少对用户的干扰。
[*]可以提高程序的性能,例如项目在窗口中不可见后,停止相关的脚本执行。
如何设置 Permissions Policy
有两种方式来指定 Permissions Policy:
[*] 通过在 HTTP 响应头中添加 Permissions-Policy 字段来实现,可以指定一系列权限,每一个权限指定一个名称和相关计谋。例如,要禁用Web API 的摄像头访问权限,添加如下 header 内容:
Permissions-Policy:camera=()
[*] 通过 的 allow 属性,控制指定的 中的特性。例如答应 iframe 全屏:
常见的 Permissions Policy 权限
以下是常见的 Permissions Policy 示例:
[*]accelerometer:控制加速计访问的权限。
[*]autoplay:控制自动播放媒体资源的权限。
[*]camera:控制摄像头访问的权限。
[*]geolocation:控制地理位置访问的权限。
[*]microphone:控制麦克风访问的权限。
[*]notifications:控制通知访问的权限。
[*]payment:控制支付访问的权限。
[*]sync-xhr:控制同步XHR请求的权限。
Permissions Policy 最佳实践
以下是几点利用 Permissions-Policy 的最佳实践:
[*]只授权应用程序所需的最低权限,以制止潜在的风险。
[*]利用 Permissions-Policy 前,务必进行全面的功能性和兼容性测试,确保不会影响应用程序的正常功能。
[*]可以渐渐引入和设置 Permissions-Policy,确保安全性的同时减少对现有应用程序的影响。
小结
Permissions Policy 是一种强大而机动的 Web API 权限控制机制,提供了更准确控制欣赏器权限的能力。通过合理设置
Permissions Policy,可以保护用户隐私、提高应用程序的安全性和提供精彩的用户体验。关于 Permissions Policy
利用相关的更详细的信息可以参考如下资料:
https://developer.mozilla.org/en-US/docs/Web/HTTP/Permissions_Policy
学习计划
那么题目又来了,作为萌新小白,我应该先学什么,再学什么?
既然你都问的这么直白了,我就告诉你,零基础应该从什么开始学起:
阶段一:初级网络安全工程师
接下来我将给大家安排一个为期1个月的网络安全初级计划,当你学完后,你基本可以从事一份网络安全相关的工作,比如排泄测试、Web排泄、安全服务、安全分析等岗位;其中,如果你等保模块学的好,还可以从事等保工程师。
综合薪资区间6k~15k
1、网络安全理论知识(2天)
①相识行业相关配景,前景,确定发展方向。
②学习网络安全相关法律法规。
③网络安全运营的概念。
④等保简介、等保规定、流程和规范。(非常重要)
2、排泄测试基础(1周)
①排泄测试的流程、分类、标准
②信息收集技能:主动/被动信息搜集、Nmap工具、Google Hacking
③毛病扫描、毛病利用、原理,利用方法、工具(MSF)、绕过IDS和反病毒侦察
④主机攻防演练:MS17-010、MS08-067、MS10-046、MS12-20等
3、操纵系统基础(1周)
①Windows系统常见功能和下令
②Kali Linux系统常见功能和下令
③操纵系统安全(系统入侵排查/系统加固基础)
4、盘算机网络基础(1周)
①盘算机网络基础、协议和架构
②网络通信原理、OSI模型、数据转发流程
③常见协议解析(HTTP、TCP/IP、ARP等)
④网络攻击技能与网络安全防御技能
⑤Web毛病原理与防御:主动/被动攻击、DDOS攻击、CVE毛病复现
5、数据库基础操纵(2天)
①数据库基础
②SQL语言基础
③数据库安全加固
6、Web排泄(1周)
①HTML、CSS和JavaScript简介
②OWASP Top10
③Web毛病扫描工具
④Web排泄工具:Nmap、BurpSuite、SQLMap、其他(菜刀、漏扫等)
https://i-blog.csdnimg.cn/blog_migrate/67dba474708d1e471a5c0d472bbf24cc.png#pic_center
那么,到此为止,已经耗时1个月左右。你已经成功成为了一名“脚本小子”。那么你还想接着往下探索吗?
阶段二:中级or高级网络安全工程师(看自己能力)
综合薪资区间15k~30k
7、脚本编程学习(4周)
在网络安全范畴。是否具备编程能力是“脚本小子”和真正网络安全工程师的本质区别。在实际的排泄测试过程中,面对复杂多变的网络情况,当常用工具不能满足实际需求的时间,往往需要对现有工具进行扩展,大概编写符合我们要求的工具、自动化脚本,这个时间就需要具备一定的编程能力。在分秒必争的CTF竞赛中,想要高效地利用自制的脚本工具来实现各种目的,更是需要拥有编程能力。
零基础入门的同砚,我建议选择脚本语言Python/PHP/Go/Java中的一种,对常用库进行编程学习
搭建开发情况和选择IDE,PHP情况保举Wamp和XAMPP,IDE剧烈保举Sublime;
Python编程学习,学习内容包含:语法、正则、文件、 网络、多线程等常用库,保举《Python核心编程》,没必要看完
用Python编写毛病的exp,然后写一个简朴的网络爬虫
PHP基本语法学习并誊写一个简朴的博客系统
熟悉MVC架构,并试着学习一个PHP框架大概Python框架 (可选)
相识Bootstrap的布局大概CSS。
阶段三:顶级网络安全工程师
如果你对网络安全入门感兴趣,那么你点击这里
页:
[1]