js实现图片粘贴上传到服务器并展示
最近看了一些有关于js实现图片粘贴上传的demo,实现如下: (这里只能检测到截图粘贴和图片右键复制之后粘贴)
demo1:
document.addEventListener('paste', function (event) {
            console.log(event)
            var isChrome = false;
            if ( event.clipboardData || event.originalEvent ) {
                //not for ie11  某些chrome版本使用的是event.originalEvent
                var clipboardData = (event.clipboardData || event.originalEvent.clipboardData);
                if ( clipboardData.items ) {
                    // for chrome
                    var  items = clipboardData.items,
                        len = items.length,
                        blob = null;
                    isChrome = true;
                    //items.length比较有意思,初步判断是根据mime类型来的,即有几种mime类型,长度就是几(待验证)
                    //如果粘贴纯文本,那么len=1,如果粘贴网页图片,len=2, items[0].type = 'text/plain', items[1].type = 'image/*'
                    //如果使用截图工具粘贴图片,len=1, items[0].type = 'image/png'
                    //如果粘贴纯文本+HTML,len=2, items[0].type = 'text/plain', items[1].type = 'text/html'
                    // console.log('len:' + len);
                    // console.log(items[0]);
                    // console.log(items[1]);
                    // console.log( 'items[0] kind:', items[0].kind );
                    // console.log( 'items[0] MIME type:', items[0].type );
                    // console.log( 'items[1] kind:', items[1].kind );
                    // console.log( 'items[1] MIME type:', items[1].type );
                    //阻止默认行为即不让剪贴板内容在div中显示出来
                    event.preventDefault();
                    //在items里找粘贴的image,据上面分析,需要循环
                    for (var i = 0; i < len; i++) {
                        if (items[i].type.indexOf("image") !== -1) {
                            //getAsFile() 此方法只是living standard firefox ie11 并不支持
                            blob = items[i].getAsFile();
                            uploadImgFromPaste(blob, 'paste', isChrome);
                        }
                    }
                    /*if ( blob !== null ) {
                        var reader = new FileReader();
                        reader.onload = function (event) {
                            // event.target.result 即为图片的Base64编码字符串
                            var base64_str = event.target.result;//获得图片base64字符串
                            //可以在这里写上传逻辑 直接将base64编码的字符串上传(可以尝试传入blob对象,看看后台程序能否解析)
                        uploadImgFromPaste(base64_str, 'paste', isChrome);
                        }
                        reader.readAsDataURL(blob);//传入blob对象,读取文件
                    }*/
                } else {
                    //for firefox
                    setTimeout(function () {
                        //设置setTimeout的原因是为了保证图片先插入到div里,然后去获取值
                        var imgList = document.querySelectorAll('#aaa img'),
                            len = imgList.length,
                            src_str = '',
                            i;
                        for ( i = 0; i < len; i ++ ) {
                            if ( imgList[i].className !== 'my_img' ) {
                                //如果是截图那么src_str就是base64 如果是复制的其他网页图片那么src_str就是此图片在别人服务器的地址
                                src_str = imgList[i].src;
                            }
                        }
                        uploadImgFromPaste(src_str, 'paste', isChrome);
                    }, 1);
                }
            } else {
                //for ie11
                setTimeout(function () {
                    var imgList = document.querySelectorAll('#aaa img'),
                        len = imgList.length,
                        src_str = '',
                        i;
                    for ( i = 0; i < len; i ++ ) {
                        if ( imgList[i].className !== 'my_img' ) {
                            src_str = imgList[i].src;
                        }
                    }
                    uploadImgFromPaste(src_str, 'paste', isChrome);
                }, 1);
            }
        })
        //调用图片上传接口,将file文件以formData形式上传
        function uploadImgFromPaste (file, type, isChrome) {
            var formData = new FormData();
            formData.append('files', file);
            formData.append('submission-type', type);
            var xhr = new XMLHttpRequest();
            xhr.open('POST', '/upload_editor_photo3');
            xhr.onload = function () {
                console.log(xhr.readyState);
                if ( xhr.readyState === 4 ) {
                    if ( xhr.status === 200 ) {
                        var data = JSON.parse(xhr.responseText),
                            editor = document.getElementById('aaa');
                        if ( isChrome ) {
                            var len=data.data.length;
                            for ( var i = 0; i < len; i ++) {
                                var img = document.createElement('img');
                                img.className = 'my_img';
                                img.src = data.data[i]; //设置上传完图片之后展示的图片
                                editor.appendChild(img);
                            }
                        } else {
                            var imgList = document.querySelectorAll('#aaa img'),
                                len = imgList.length,
                                i;
                            for ( i = 0; i < len; i ++) {
                                if ( imgList[i].className !== 'my_img' ) {
                                    imgList[i].className = 'my_img';
                                    imgList[i].src = data.data[i];
                                }
                            }
                        }
                    } else {
                        console.log( xhr.statusText );
                    }
                };
            };
            xhr.onerror = function (e) {
                console.log( xhr.statusText );
            }
            xhr.send(formData);
        }
demo2:
// 处理粘贴事件
$("#aaa").on('paste', function(eventObj) {
// 处理粘贴事件
var event = eventObj.originalEvent;
var imageRe = new RegExp(/image\/.*/);
var fileList = $.map(event.clipboardData.items, function (o) {
if(!imageRe.test(o.type)){ return }
var blob = o.getAsFile();
return blob;
});
if(fileList.length <= 0){ return }
upload(fileList);
//阻止默认行为即不让剪贴板内容在div中显示出来
event.preventDefault();
});
function upload(fileList) {
for(var i = 0, l = fileList.length; i < l; i++){
var fd = new FormData();
var f = fileList[i];
fd.append('files', f);
var editor=document.getElementById("aaa");
$.ajax({
url:"/upload_editor_photo3",
type: 'POST',
dataType: 'json',
data: fd,
processData: false,
contentType: false,
xhrFields: { withCredentials: true },
headers: {
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Credentials': 'true'
},
success: function(res){
var len=res.data.length;
for ( var i = 0; i < len; i ++) {
var img = document.createElement('img');
img.src = res.data[i]; //设置上传完图片之后展示的图片
editor.appendChild(img);
}
},
error: function(){
alert("上传图片错误");
}
});
}
}
注意:因为只支持右键复制图片,所以并不能一下复制两张图片,所有图片复制并粘贴上传待研究.
html:
<div id="aaa" contentEditable="true" style="height:800px;border:1px solid #ccc"></div>
接口返回数据格式:
{
    // errno 即错误代码,0 表示没有错误。
    //       如果有错误,errno != 0,可通过下文中的监听函数 fail 拿到该错误码进行自定义处理
    errno: 0,
    // data 是一个数组,返回若干图片的线上地址
    data: [
        '图片1地址',
        '图片2地址',
        '……'
    ]
}
参考部分:http://www.jb51.net/article/80657.htm
js实现图片粘贴上传到服务器并展示的更多相关文章
- ueditor+复制word图片粘贴上传
		Chrome+IE默认支持粘贴剪切板中的图片,但是我要发布的文章存在word里面,图片多达数十张,我总不能一张一张复制吧?Chrome高版本提供了可以将单张图片转换在BASE64字符串的功能.但是无法 ... 
- [转]Kindeditor图片粘贴上传(chrome)
		原文地址:https://www.cnblogs.com/jsper/p/7608004.html 首先要赞一下kindeditor,一个十分强大的国产开源web-editor组件. kindedit ... 
- HTML5裁剪图片并上传至服务器实现原理讲解
		HTML5裁剪图片并上传至服务器实现原理讲解 经常做项目需要本地上传图片裁剪并上传服务器,比如会议头像等功能,但以前实现这类需求都很复杂,往往需要先把图片上传到服务器,然后返回给用户,让用户确定裁 ... 
- 如何实现一个 markdown 图片粘贴上传的博客后台系统
		如何实现一个 markdown 图片粘贴上传的博客后台系统 js 实现 drag & drop / copy & paste image uploader MongoDB 设计文档对象 ... 
- HTML5 Canvas前台压缩图片并上传到服务器
		1.前台代码: <input id="fileOne" type="file" /> <input id="btnOne" ... 
- HTML5 本地裁剪图片并上传至服务器(转)
		很多情况下用户上传的图片都需要经过裁剪,比如头像啊什么的.但以前实现这类需求都很复杂,往往需要先把图片上传到服务器,然后返回给用户,让用户确定裁剪坐标,发送给服务器,服务器裁剪完再返回给用户,来回需要 ... 
- SpringMvc  +  Jsp+  富文本 kindeditor 进行  图片ftp上传nginx服务器 实现
		一:html 原生态的附件上传 二:实现逻辑分析: 1.1.1 需求分析 Common.js 1.绑定事件 2.初始化参数 3.上传图片的url: /pic/upload 4.上图片参数名称: upl ... 
- Kindeditor图片粘贴上传(chrome)
		kindeditor4.1.x版本已支持图片批量上传,不过传统的选文件上传的方式依然效率低下. 很多时候,编辑人员可能需要将一个文档中图片上传到网上,那么,按照传统的上传方法,他必须先将图片另存为到本 ... 
- ueditor 图片粘贴上传,实现图文粘贴,图片自动上传
		如何做到 ueditor批量上传word图片? 1.前端引用代码 <!DOCTYPEhtmlPUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN& ... 
随机推荐
- java获取上周任意一天的日期
			/** * 获取上周周几的日期,默认一周从周一开始 * @param dayOfWeek * @param weekOffset * @return */ public static Date get ... 
- [转]Linux 命令行快捷键
			群里有人问"问个问题,Linux 命令行有没有快捷键一下从行末会到行头?经常敲了很多命令发现忘加 sudo 了,然后把命令删了重新敲一遍". 自己还真不知道怎么操作,只知道历史命令 ... 
- 关于face alglimnment各种资料,存下来有空慢慢看
			人脸对齐和应用 机器学习--详解人脸对齐算法SDM-LBF 基于MTCNN的人脸自动对齐技术原理及其Tensorflow实现测试 人脸检测——MTCNN CVPR论文<Face Alignmen ... 
- window.print()局部打印三种方式
			首先准备要打印的内容,也可以打印时再填充,html中定义如下: <!--startprint--> <div id="printcontent" style=&q ... 
- background-size 导致的背景不居中问题
			1. 理想中的效果是这样的 2. 然后想改一下圆圈的大小 3. 容器大小为偶数,图片大小为奇数,就会使图片并不真正居中,如果仔细量一下,会发现图片上面比下面多1px! 貌似只有 backgro ... 
- ASP.NET Core 2.0使用Log4net实现记录日志功能
			一.安装Log4net 1.使用Nuget包进行安装 在依赖项上面右键,选择“管理NuGet程序包”,如下图所示: 在浏览界面输入log4net,然后点击安装,如下图所示: 2.使用程序包管理器控制台 ... 
- Qt之创建自定义类型
			摘要: 简述 当使用Qt创建用户界面时,特别是那些带有特殊控制和特征的界面时,开发者通常需要创建新数据类型来扩展或替换Qt现有的的值类型集合. 标准类型,比如:QSize.QColor和QString ... 
- SDRAM 学习笔记(一)
			前面几篇博客已经讲到了关于0V7725的相关驱动问题,那么OV7725驱动成功之后,设定OV7725输出RGB565格式,那么对于640x480x16,那么若是选用FIFO,应该设置为位宽16bit, ... 
- IDEA中maven项目导jar包太慢
			版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/PROGRAM_anywhere/article/details/53842058参考了网上的一些教程 ... 
- Simsimi  小黄鸡机器人最新无限制接口api simsimi机器人接口api 微信公众号
			一.什么是Simsimi? simsimi公司是提供智能服务,其中一个服务是simsimi聊天机器人服务,每天有超过百万的用户聊天,国内最大的搜索引擎——百度的产品siri使用的就是simsimi提供 ... 
