この単純な例では、メタhttp-equivヘッダーでCSPヘッダーを設定しようとしています。 base64イメージを含め、Chromeでイメージをロードしようとしています。
data
キーワードでそれを行うべきだと思いましたが、どういうわけか機能しません。
開発者ツールで次のエラーが表示されるだけです。
画像をロードすることを拒否した「データ:画像/ PNGを、base64で、R0lGODlhDwAPAOZEAMkJCfAwMMYGBtZMTP75 + euIiPFBP + hVVf3v7 ... nw7yk4Mjr6GLUY + joiBI2QAACABwJDCHgoKOHEoAYVBAgY8GGAxAoNGAmiwMHBCgccKDAKBAA7」は、次のコンテンツセキュリティポリシーの指示に違反しているため、「IMG SRC-『自己』のデータを」。
サンプルコード(JSFiddleはメタヘッダーを設定できないため、この例では動作しません):
<html>
<head>
<meta http-equiv="Content-Security-Policy" content="
default-src 'none';
style-src 'self' 'unsafe-inline';
img-src 'self' data;
" />
<style>
#helloCSP {
width: 50px;
height: 50px;
background: url() no-repeat;
border: 1px solid red;
}
</style>
</head>
<body>
<h1>CSP</h1>
<div id="helloCSP"></div>
</body>
</html>
ここでこの例を開くこともできます。
https://dl.dropboxusercontent.com/u/638360/ps/csp.html
CSP仕様の文法 によれば、スキームをscheme
だけでなくscheme:
として指定する必要があります。そのため、画像ソースディレクティブを次のように変更する必要があります。
img-src 'self' data:;