内容安全政策“数据”;不工作的base64图像在Chrome 28

在这个简单的例子中,我试图用meta http-equiv报头设置一个CSP报头。我包括一个base64图像,我试图让Chrome加载图像。

我认为data关键字应该这样做,

我只是在开发工具中得到以下错误:

拒绝加载图像“…nw7yk4Mjr6GLUY+joiBI2QAACABwJDCHgoKOHEoAYVBAgY8GGAxAoNGAmiwMHBCgccKDAKBAA7”,因为它违反了以下内容安全策略指令:“img-src 'self' data”。

示例代码(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 < / p >

154877 次浏览

根据CSP规范中的语法,你需要将方案指定为scheme:,而不仅仅是scheme。因此,你需要将图像源指令更改为:

img-src 'self' data:;

试试这个

要加载的数据:

<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'><path fill='#343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/></svg>

获取一个utf8到base64的转换器,并将“svg”字符串转换为:

PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCA0IDUn
PjxwYXRoIGZpbGw9JyMzNDNhNDAnIGQ9J00yIDBMMCAyaDR6bTAgNUwwIDNoNHonLz48L3N2Zz4=

CSP是

img-src data: image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCA0IDUn
PjxwYXRoIGZpbGw9JyMzNDNhNDAnIGQ9J00yIDBMMCAyaDR6bTAgNUwwIDNoNHonLz48L3N2Zz4=