kronos/csp
最新稳定版本:v2.3.0
Composer 安装命令:
composer require kronos/csp
包简介
A Content-Security-Policy header builder
README 文档
README
A PHP Content-Security-Policy header generator library.
Usage
Using the Builder:
$factory = new \Kronos\ContentSecurityPolicy\Factory(); $builder = $factory->createContentSecurityPolicyBuilder(); $builder->setDefaultSrc(\Kronos\ContentSecurityPolicy\Policy::FETCH_NONE); $policy = $builder->getContentSecurityPolicy(); header($policy->getHeader());
Using the PolicyDirectorInterface:
Director class:
use Kronos\ContentSecurityPolicy\Factory; use Kronos\ContentSecurityPolicy\Policy; use Kronos\ContentSecurityPolicy\PolicyDirectorInterface; class Director implements PolicyDirectorInterface { /** @var Factory */ protected $factory; ... /** * @param Factory $factory * ... */ public function __construct(Factory $factory, ...) { $this->factory = $factory; ... } public function buildContentSecurityPolicy() { $builder = $this->factory->createContentSecurityPolicyBuilder(); $builder->setDefaultSrc([Policy::FETCH_NONE]); $builder->setObjectSrc([Policy::FETCH_NONE]); $builder->setStyleSrc([ 'mysite.example/css', 'fonts.googleapis.com', 'fonts.gstatic.com', Policy::FETCH_UNSAFE_INLINE ]); $builder->setFontSrc([ 'mysite.example/fonts', 'fonts.googleapis.com', Policy::FETCH_UNSAFE_INLINE ]); $builder->setFrameAncestors([Policy::FETCH_NONE]); $builder->setReportUri('mysite.example/api/csp-report/'); $builder->setReportOnly(); return $builder->getContentSecurityPolicy(); } }
Code:
$factory = new \Kronos\ContentSecurityPolicy\Factory(); $director = new Director($factory); $policy = $director->buildContentSecurityPolicy(); header($policy->getHeader());
统计信息
- 总下载量: 191.44k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2018-01-11