我试图在获得图像之前先在画布上绘制图像dataURL()
,但是返回的数据就像是空的。
当我在控制台中检查它时,我发现A
字符串中有很多:("data:image/png;base64,iVBO..some random chars... bQhfoAAAAAAAAAA... a lot of A ...AAAASUVORK5CYII="
)
当我尝试将画布附加到文档时,也没有绘制任何内容,并且控制台中没有引发任何错误。
这里有什么问题 ?
这是我的代码:
var img = new Image();
img.src = "http://somerandomWebsite/picture.png";
var canvas = document.createElement('canvas');
canvas.width = img.width;
canvas.height = img.height;
var context = canvas.getContext('2d');
context.drawImage(img, 0,0); // this doesn't seem to work
var dataURL = canvas.toDataURL(); // this will give me a lot of "A"
doSomething(dataURL);
另外,进行快速刷新时,图像会正确绘制到画布上,但是控制台中出现错误消息,并且dataURL
为空。
Firefox中的消息是: “ SecurityError:操作不安全。” ,
在Chrome中是 “未捕获的安全错误:无法在’HTMLCanvasElement’上执行’toDataURL’:污染的画布可能无法导出。” ,
而在IE上,我刚得到 “ SecurityError” 。
这是什么意思 ?
您必须等待图像 加载 完毕才能在画布上绘画。
为此,只需使用load
您<img>
元素的事件处理程序即可:
// create a new image
var img = new Image();
// declare a function to call once the image has loaded
img.onload = function(){
var canvas = document.createElement('canvas');
canvas.width = img.width;
canvas.height = img.height;
var context = canvas.getContext('2d');
context.drawImage(img, 0,0);
var dataURL = canvas.toDataURL();
// now you can do something with the dataURL
doSomething(dataURL);
}
// now set the image's src
img.src = "http://somerandomWebsite/picture.png";
此外,在画布context.toDataURL()
,并context.getImageData
能正常工作,你必须让在你的图像资源跨域兼容的方式,否则画布‘污点’,这意味着任何获得的像素数据的方法将被阻止。
img.crossOrigin
为"use-credentials"
。 img.crossOrigin
为"anonymous"
。Nota Bene :CORS 标头由服务器发送,该cross-origin
属性只会让它知道您要使用CORS来获取图像数据,如果 服务器 设置不正确,您将无法绕开它。
另外,某些UserAgent(IE和Safari)仍未实现此属性。
边缘案例 :如果某些图像来自服务器,而某些图像来自CORS兼容的服务器,则您可能需要使用onerror
事件处理程序,如果将cross-origin
属性设置"anonymous"
为非CORS服务器,则该事件处理程序将触发。
function corsError(){
this.crossOrigin='';
this.src='';
this.removeEventListener('error', corsError, false);
}
img.addEventListener('error', corsError, false);
我使用Spring Boot和使用Spring Cloud APIGW的微服务堆栈。我使用这里提到的相同代码:https://piotrminkowski.com/2020/02/20/microservices-api-documentation-with-springdoc-openapi/ 当我到达任何一个endpoint时,我都看不到响应正在到来并低于错误。 CORS 策略已阻止从源“ht
问题内容: 我有一个ListView,并且在每个列表项中都有一些TextViews和一个CheckBox。当我检查一个CheckBox并触发onCheckedChangeListener时,一切都会正常进行。但是,一旦选中一个随机的其他复选框。这是一个例子。 如果我单击第一个CheckBox:选中8。检查15。已检查21。已检查27。检查33。检查41。然后,如果我一直向上滚动,则直到6都不会检查
问题内容: 当我有代码时,它将停止所有其他命令的工作。我试过了,但这也不起作用。这是我的代码: 问题答案: 您必须放置在语句范围之外,无论消息是否以“ / lockdown”开头,都应运行。 顺便说一下,不适用于。尽管没有任何错误(因为已经进行了检查),但实际上并没有按您期望的那样工作。 装饰器的替代方法是:
问题内容: 我正计划通过向信用卡收费来销售产品,因此使用SSL对于Django支持的网站至关重要。我对此非常幼稚。 我最初的django设置计划是使用Apache作为网络服务器,并使用mod_wsgi与Django再次由Apache服务的静态媒体进行通信。在SSL协议进入计划之前,一切似乎都很好。 我将在用户帐户配置页面,整个购买过程以及django管理员处使用SSL协议。 我已经检查了官方文档并
我在CI和Typeahead方面有一些问题,我没有得到任何结果/ JS CI控制器 CI模型 和视图 有人能帮我解决这个问题吗?
提前谢了。