本人扩展了KindEditor4.1.10,使得他能够在Chrome和IE11中直接粘贴复制的图片(比如通过截图工具把图片直接保存在剪切板中),然后调用上传URL上传图片

方法,修改kindeditor.js中的代码:

在5825行附近大概是下面这个样子的:

  1. K(doc.body).bind('paste', function (e) {
  2. if (self.pasteType === 0) {
  3. e.stop();
  4. return;
  5. }

在第1行和第2行之间插入:

  1. //处理IE11,Chrome粘贴图片上传
  2. function dopasteImg() {
  3. //debugger;
  4. var file = null;
  5. if (window.clipboardData) {//ie
  6. if (clipboardData.files && clipboardData.files.length)//IE11
  7. file = clipboardData.files[0];
  8. else if (!clipboardData.getData("text") && !clipboardData.getData("url")) {
  9. alert("不能粘贴文件或图片,请使用IE11或者Chrome浏览器,或使用上传功能");
  10. return true;
  11. }
  12. } else {
  13. if (e.event.clipboardData.items)//chrome
  14. for (var i = 0; i < e.event.clipboardData.items.length; i++) {
  15. if (e.event.clipboardData.items[i].kind === "file") {
  16. file = e.event.clipboardData.items[i];
  17. break;
  18. }
  19. }
  20. if (file == null) {
  21. if (!e.event.clipboardData.getData("url") && !e.event.clipboardData.getData("text")) {
  22. alert("不能粘贴文件或图片,请使用IE11或者Chrome浏览器,或使用上传功能");
  23. return true;
  24. }
  25. }
  26. }
  27. if (file) {
  28. if (!K.undef(self.allowImageUpload, true)) {
  29. alert("编辑器禁止上传图片,请与有关人员联系!");
  30. return true;
  31. }
  32. //获取File Blob
  33. //debugger;
  34. var blb;
  35. if (file.getAsFile) {//Chrome
  36. blb = file.getAsFile();
  37. if (blb.size === 0) {
  38. alert("不能获取剪切板中的" + (file.type.indexOf("image/") === 0 ? "图像" : "文件")
  39. +"\n如果是从OutLook中复制的,请换其他程序,如Word");
  40. return true;
  41. }
  42. sendfile(blb, file.type);
  43. } else {
  44. var fr = new FileReader();
  45. if (fr.readAsArrayBuffer) {//ie
  46. fr.onloadend = function (evt) {
  47. blb = evt.target.result;
  48. sendfile(blb, file.type);
  49. }
  50. fr.readAsArrayBuffer(file);
  51. }
  52. }
  53. function sendfile(b, t) {
  54. var xhr = new XMLHttpRequest();
  55. var formData = new FormData();
  56. var isImg = t.indexOf("image/") === 0;
  57. //formData.append('imgFile', file,"untitled." + t.split('/')[1]);
  58. //formData.append('imgFile', b);
  59. var myBlob = new Blob([b], { "type": t });
  60. formData.append('imgFile', myBlob, "untitled." + t.split('/')[1]);
  61. //formData.append('imgFile', b);
  62. formData.append('dir', isImg ? 'image' : 'file');
  63. xhr.open('POST', self.uploadJson);
  64. xhr.onreadystatechange = function () {
  65. if (xhr.readyState == 4&&xhr.status == 200) {
  66. // if (fn) {
  67. var data = _trim(xhr.responseText);
  68. //if (dataType == 'json') {
  69. data = _json(data);
  70. if (data.error) {
  71. if (typeof ($) !== "undefined" && $.messager && $.messager.alert) {
  72. $.messager.alert('Error', data.message, 'warning');
  73. } else {
  74. alert(data.message);
  75. }
  76. } else {
  77. //self.exec('insertimage', url, title, width, height, border, align);
  78. if(K.undef(self.formatUploadUrl, true))
  79. data.url =K.formatUrl(data.url, 'absolute');
  80. self.exec('insertimage', data.url, "from clipboard", undefined, undefined, undefined, undefined);
  81. }
  82. //}
  83. // fn(data);
  84. // }
  85. }
  86. }
  87. xhr.send(formData);
  88. }
  89. return true;
  90. }
  91. }
  92. //debugger;
  93. if (dopasteImg())
  94. e.stop();
  95. //处理粘贴结束5825

此代码在chrome中测试通过,上传文件的服务器端处理无须改变,本代码已在chrome v35,IE11上测试通过

其中处理的几个例外情况是:

    1. .在IE11和Chrome以外的浏览器中,如果复制了图片,粘贴,有可能会粘贴成<img src="data:img/png:base64:xxxxxx"..../>这种形式的,如IE10或者Firefox,但也可能会粘贴成<img src="本地路径" 这种格式的,前一种格式,如果通过一些复杂的处理,做成上传比较容易(或者直接不处理,但这只能显示在支持这种HTML5格式的浏览器中),但后一种情况,如从OutLook收件箱中复制的图片,本人认为处理会很复杂,所以简单起见,禁止这些情况的粘贴
    2. 在chrome中,如果复制了Outlook收件箱的图片,在剪切板中是找不到这个文件的内容的(file.size==0),这种情况下的粘贴也会被禁止并提示
    3. 在IE11和Chrome中都有FormData对象,所以当能取到文件的时候一定是IE11或者Chrome
    4. 如果是火狐浏览器,pasteType设置为2即可,且在引用时判断浏览器类型如为火狐。则用form-data方式进行存储。(暂时找不到更好的办法,望指教)

KindEditor4.1.10,支持粘贴图片(转载!)的更多相关文章

  1. KindEditor4.1.10,支持粘贴图片

    转载自https://blog.csdn.net/jimmy0021/article/details/73251406 我已经忘记我是不是从这个博主的那里找到的解决kindeditor粘贴图片的方法了 ...

  2. kindeditor-4.1.10 结合 Asp.Net MVC 添加图片功能

    KindEditor是一套开源的HTML可视化编辑器,现在我要结合Asp.Net MVC4 上传图片功能,做相应的配置和修改, 其实网上也有人写过类似的文章了,我写出来是以防以后使用的时候出现这样的问 ...

  3. 让input支持 ctrl v上传粘贴图片? 让input支持QQ截图或剪切板中的图像数据(Java实现保存)

    原理:监听粘贴 → 获取粘贴内容 → 将内容上传 → 抓取后返回替换至input 我们在生产中用到的界面: 测试地址 http://sms.reyo.cn 用户名:aa 密码:123456 以下是PH ...

  4. Ckeditor 中粘贴图片

    我们在ckeditor 中有上传图片,但是实际使用中这种手动上传图片方式并不是很方便,而是复制或者截图粘贴图片. 这里我们实现主要是获取对应的粘贴事件. CKEDITOR.instances[&quo ...

  5. WORD粘贴图片+DEDE

    自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了.一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器) ...

  6. ckeditor从word粘贴图片

    自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了.一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器) ...

  7. ckeditor直接粘贴图片实现

    自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了.一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器) ...

  8. ckeditor实现WORD粘贴图片自动上传,jsp应用

    官网地址http://ueditor.baidu.com Git 地址 https://github.com/fex-team/ueditor 参考博客地址 http://blog.ncmem.com ...

  9. ckeditor富文本编辑器的使用和图片上传,复制粘贴图片上传

    自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了.一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器) ...

随机推荐

  1. Audio Session Interruption

    近期处理了一个挂断电话后,莫名手机开始播放音乐的Bug. 所以顺便在这总结一下,对于IOS的AudioSession中断的几种处理情况. 一.通过C语言的init方法配置interruptionl回调 ...

  2. tr用法

    参考: http://man.linuxde.net/tr shell脚本学习指南 语法 tr [options] source-char-list replace-char-list 用途 转换字符 ...

  3. CodeMirror很好用

    基于Javascript的web的文本编辑器 各种强大 支持多种语言的语法高亮, 多种主题 vim ,emacs  快捷键

  4. 查看IIS哪个应用程序池占用CPU过高

    1. 进入cmd 2. %systemroot%\system32\inetsrv\AppCmd.exe list wp       这样就能找到活动的应用程序池的PID了 3. 对照资源管理器的PI ...

  5. 。。。再战JQuery。。。

    今天从学习JQurery的第一个函数开始!!! JQuery里面的show这个函数很不错,我很喜欢,他的使用方法如下:JQuery对象.show(speed,callback); speed你可以指定 ...

  6. 转:客制FORM调用会计科目弹性域/根据科目取得CODE_COMBINATION_ID

    1.首先在创建数据表时,添一个字段用来保存会计科目的ID.如:CODE_COMBINATION_ID 2.在FORM相应的数据块增加两个ITEM,用来显示科目NUMBER与DESCRITION. 例: ...

  7. 《zw版·Halcon-delphi系列原创教程》 只有2行代码的超市收款单ocr脚本

    <zw版·Halcon-delphi系列原创教程> 只有2行代码的超市收款单ocr脚本只有2行代码的超市收款单ocr脚本 发了这么多教程,有网友问,为什么没有ocr的.      的确,在 ...

  8. runoob

    今天学习bootstrap的时候偶然发现http://www.runoob.com/ 这个网站不错,比w3cschool界面要好看,内容要丰富 比较适合新手学习,而且上面的内容比较丰富,不错.

  9. Android Layout XML属性

    转载自并做少量添加:http://www.cnblogs.com/playing/archive/2011/04/07/2008620.html Layout对于迅速的搭建界面和提高界面在不同分辨率的 ...

  10. 轻量级IOC框架SwiftSuspenders

    该框架的1.6版本位于https://github.com/tschneidereit/SwiftSuspenders/blob/the-past/,现在已经出了重新架构的2.0版本,所以我决定先研究 ...