Dans cet exemple simple, j'essaie de définir un en-tête CSP avec l'en-tête meta http-equiv. J'ai inclus une image base64 et j'essaye de faire charger Chrome à l'image.
Je pensais que le data
mot - clé devrait faire ça, mais d'une manière ou d'une autre ça ne marche pas.
Je reçois simplement l'erreur suivante dans les outils de développement:
Refus de charger l'image 'data: image / png; base64, R0lGODlhDwAPAOZEAMkJCfAwMMYGBtZMTP75 + euIiPFBP + hVVf3v7… nw7yk4Mjr6GLUY + joiBI2QAACABwJDCHgoKOHEAAYVBAGK
L'exemple de code (JSFiddle ne fonctionne pas pour cet exemple car je ne peux pas y définir de méta-en-tête):
<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>
Vous pouvez également ouvrir cet exemple ici:
https://dl.dropboxusercontent.com/u/638360/ps/csp.html
la source
Essaye ça
données à charger:
obtenir un convertisseur utf8 en base64 et convertir la chaîne "svg" en:
et le CSP est
la source