?
欢迎来到DIVCSS5查找CSS资料与学习DIV CSS布局技术!
您的位置:22选5河南最新开奖今 > WEB标准 >

??解释如何解决画布图像getImageData,toDataURL跨域问题

22选5河南最新开奖今 www.gsf5k.cn  一、首先,图片服务器需要配置Access-Control-Allow-Origin

一般团队都会有一个专门域名放置静态资源,例如腾讯是gtimg.com,百度是bdimg.com;或者很多团队使用的是腾讯云或者阿里云的服务。

而主页面所在域名往往不一样,当需要需要对canvas图片进行getImageData()或toDataURL()操作的时候,跨域问题就出来了,而且跨域问题还不止一层。

首先,第一步,图片服务器需要配置Access-Control-Allow-Origin信息,例如:

如PHP添加响应头信息,*通配符表示允许任意域名:

header("Access-Control-Allow-Origin: *");

或者指定域名:

header("Access-Control-Allow-Origin: www.zhangxinxu.com");

此时,Chrome浏览器就不会有Access-Control-Allow-Origin相关的错误信息了,但是,还会有其他的跨域错误信息。

二、canvas图片getImageData cross-origin跨域问题

对于跨域的图片,只要能够在网页中正常显示出来,就可以使用canvas的drawImage() API绘制出来。但是如果你想更进一步,通过getImageData()方法获取图片的完整的像素信息,则多半会出错。

举例来说,使用下面代码获取github上的自己头像图片信息:

var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');

var img = new Image();
img.onload = function () {
    context.drawImage(this, 0, 0);
    context.getImageData(0, 0, this.width, this.height);
};
img.src = 'https://avatars3.githubusercontent.com/u/496048?s=120&v=4';';

如需转载,请注明文章出处和来源网址://www.gsf5k.cn/w3c/w50970.shtml

我要分享到:

必备CSS教程 Essential CSS Tutorials

必备HTML基础教程 Essential HTML Tutorials

如对文章有任何疑问请提交到DIV CSS论坛,或有任何网页制作CSS问题立即到CSS论坛发贴求解 或 直接DIVCSS5网页顶部搜索遇到DIVCSS疑问。
22选5河南最新开奖今文章修订日期:2018-10-23 14:06 原创:22选5河南最新开奖今
本文22选5河南最新开奖今 www.gsf5k.cn DIVCSS5版权所有。

  • 外交部发言人陆慷就美方公布对华贸易措施答记者问 2019-05-26
  • 1230余万元省级福彩公益金助力宿迁24个公益项目 2019-05-26
  • 城区加大扬尘污染治理力度 所有施工现场必须安装视频监控 2019-05-26
  • 持之以恒打好“节点战” 2019-05-25
  • 把“就业率首超本科” 当作高职新起点 2019-05-25
  • 都昌一代课教师无证上岗体罚学生? 县教体局称将辞退 2019-05-25
  • 《英雄联盟》2018职业联赛春季赛决赛28日首发阵容公布 2019-05-24
  • 新科欧洲状元 五盾军团能否延续法兰西之夏荣耀 2019-05-24
  • 习近平为传统文化“代言” 2019-05-24
  • 成龙晒罕见旧照怀念父亲 三代同堂温馨和乐 2019-05-23
  • 网络医疗广告套路太多迷人眼 消费者讲述被坑经历 2019-05-23
  • 邮储银行山西省分行零售信贷结余突破200亿元 2019-05-23
  • 兰州文创城中线桥项目有序推进 全长约4.2km直通安宁区 2019-05-22
  • 中央环保督察组:石家庄市无极县“敷衍整改” 2019-05-22
  • 人工智能正在改变世界 中国围棋大会与您共迎未来 2019-05-21
  • 106| 670| 627| 50| 327| 36| 844| 713| 110| 123|