js关于getImageData跨域问题的解决方法


Posted in Javascript onOctober 14, 2016

在学习h5的时候,canvas标签中getImageData()报错:security error

具体代码如下(chrome浏览器):

function createGSCanvas(img){
 var canvas=document.createElement("canvas");
 canvas.width=img.width;
 canvas.height=img.height;
 var ctx=canvas.getContext("2d");
 ctx.drawImage(img,0,0);

 var c=ctx.getImageData(0,0,img.width,img.height);
 for(var i=0;i<c.height;i++){
  for(var j=0;j<c.width;j++){
   var x=(i*4)*c.height+(j*4);
   var r=c.data[x];
   var g=c.data[x+1];
   var b=c.data[x+2];
   c.data[x]=c.data[x+1]=c.data[x+2]=(r+g+b)/3;

  }
 }
 ctx.putImageData(c,0,0,0,0,c.width,c.height);
 return canvas.toDataURL();
}

报错信息如下:Uncaught SecurityError: Failed to execute 'getImageData' on 'CanvasRenderingContext2D': The canvas has been tainted by cross-origin data.

原因:createGSCanvas()调用了getImageData函数,但是图片存储在本地文件,默认为没有域名,chrome浏览器判定为跨域才报错!

解决方法:1、将图片放置在服务器中,由服务器返回给客户端浏览器,遵循同源策略;

                    2、在IE、Firefox浏览器中打开。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
document.createElement()用法及注意事项(ff下不兼容)
Mar 13 Javascript
js数组中如何随机取出一个值
Jun 13 Javascript
JavaScript实现MIPS乘法模拟的方法
Apr 17 Javascript
javascript动态创建链接的方法
May 13 Javascript
jQuery鼠标经过方形图片切换成圆边效果代码分享
Aug 20 Javascript
AngularJS中如何使用$http对MongoLab数据表进行增删改查
Jan 23 Javascript
jQuery实现公告新闻自动滚屏效果实例代码
Jul 14 Javascript
基于HTML5+JS实现本地图片裁剪并上传功能
Mar 24 Javascript
vue如何集成raphael.js中国地图的方法示例
Aug 15 Javascript
客户端(vue框架)与服务器(koa框架)通信及服务器跨域配置详解
Aug 26 Javascript
微信小程序实现自定义加载图标功能
Jul 19 Javascript
Vue路由管理器Vue-router的使用方法详解
Feb 05 Javascript
AngularJS 与Bootstrap实现表格分页实例代码
Oct 14 #Javascript
深入学习js瀑布流布局
Oct 14 #Javascript
微信小程序 地图定位简单实例
Oct 14 #Javascript
Bootstrap作品展示站点实战项目2
Oct 14 #Javascript
JS控制页面跳转时未请求要跳转的地址怎么回事
Oct 14 #Javascript
js中json处理总结之JSON.parse
Oct 14 #Javascript
Bootstrap优化站点资源、响应式图片、传送带使用详解3
Oct 14 #Javascript
You might like
php在项目中寻找代码的坏味道(综艺命名)
2012/07/19 PHP
php实现的微信红包算法分析(非官方)
2015/09/25 PHP
PHP队列场景以及实现代码实例详解
2021/02/26 PHP
js下关于onmouseout、事件冒泡的问题经验小结
2010/12/09 Javascript
用javascript对一个json数组深度赋值示例
2014/07/27 Javascript
jquery操作HTML5 的data-*的用法实例分享
2014/08/17 Javascript
js实现兼容IE、Firefox的图片缩放代码
2015/12/08 Javascript
获取阴历(农历)和当前日期的js代码
2016/02/15 Javascript
Javascript中作用域的详细介绍
2016/10/06 Javascript
基于hover的用法实例(推荐)
2017/07/04 Javascript
BootStrap自定义popover,点击区域隐藏功能的实现
2018/01/23 Javascript
three.js实现圆柱体
2018/12/30 Javascript
详解在Javascript中进行面向切面编程
2019/04/28 Javascript
深入了解JavaScript 私有化
2019/05/30 Javascript
vue如何限制只能输入正负数及小数
2019/07/04 Javascript
vue表单数据交互提交演示教程
2019/11/13 Javascript
解决Vue 移动端点击出现300毫秒延迟的问题
2020/07/21 Javascript
解决vue-cli输入命令vue ui没效果的问题
2020/11/17 Javascript
使用IronPython把Python脚本集成到.NET程序中的教程
2015/03/31 Python
Django中对数据查询结果进行排序的方法
2015/07/17 Python
numpy:np.newaxis 实现将行向量转换成列向量
2019/11/30 Python
nginx搭建基于python的web环境的实现步骤
2020/01/03 Python
python批量修改xml属性的实现方式
2020/03/05 Python
CSS3实现歌词进度文字颜色填充变化动态效果的思路详解
2020/06/02 HTML / CSS
丝芙兰法国官网:SEPHORA法国
2016/09/01 全球购物
FORZIERI福喜利中国官网:奢侈品购物梦工厂
2019/05/03 全球购物
历史学专业推荐信
2013/11/06 职场文书
高一自我鉴定
2013/12/17 职场文书
财务会计专业求职信范文
2013/12/31 职场文书
自我评价格式
2014/01/06 职场文书
社团活动策划书范文
2014/01/09 职场文书
购房协议书
2014/04/11 职场文书
学校教研活动总结
2014/07/02 职场文书
股东出资证明书范例
2014/10/04 职场文书
2007年老电脑安装win11会怎么样? 网友实测win11在老电脑运行良好
2021/11/21 数码科技
A22国内电台短波广播频率表
2022/05/10 无线电