自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了。一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器)中时,编辑器都无法自动上传图片。需要用户手动一张张上传Word图片。如果只有一张图片还能够接受,如果图片数量比较多,这种操作就显得非常的麻烦。

1、只粘贴图片并上传到服务器

config.extraPlugins = 'uploadimage';

//config.uploadUrl = '上传路径';

config.imageUploadUrl= '上传路径';

请求

文件上传的默认请求是一个文件,作为具有“upload”字段的表单数据。

响应:文件已成功上传

当文件成功上传时的JSON响应:

uploaded- 设置为1。

fileName - 上传文件的名称。

url - 上传文件的URL。

响应:文件无法上传

uploaded- 设置为0。

error.message - 要显示给用户的错误消息。

using System;

using System.Web;

using System.IO;

namespace WordPasterCK4

{

publicpartialclassupload : System.Web.UI.Page

{

protectedvoid Page_Load(object sender, EventArgs e)

{

string fname = Request.Form["UserName"];

int len = Request.ContentLength;

if (Request.Files.Count > 0)

{

DateTime timeNow = DateTime.Now;

string uploadPath = "/upload/" + timeNow.ToString("yyyyMM") + "/" + timeNow.ToString("dd") + "/";

string folder = Server.MapPath(uploadPath);

//自动创建目录

if (!Directory.Exists(folder)) Directory.CreateDirectory(folder);

HttpPostedFile file = Request.Files.Get(0);

//原始文件名称,由控件自动生成。

//md5.png,crc.png,uuid.png,sha1.png

string nameOri = file.FileName;

string ext = Path.GetExtension(nameOri).ToLower();

//只支持图片上传

if (    ext == ".jpg"

||  ext == ".jpeg"

||  ext == ".png"

||  ext == ".gif"

||  ext == ".bmp")

{

string filePathSvr = Path.Combine(folder, nameOri);

//

if(!Directory.Exists(filePathSvr)) file.SaveAs(filePathSvr);

Response.Write("http://10.168.4.209:83" + uploadPath + nameOri);

}

}

}

}

}

2、粘贴word里面的图片路径是fill://D 这种格式 我理解这种是非浏览器安全的 许多浏览器也不支持

目前项目是用了一种变通的方式:

先把word上传到后台 、poi解析、存储图片 、转换html、替换图片、放到富文本框里显示

(富文本显示有个坑:没找到直接给富文本赋值的方法 要先销毁 记录下

var WordPasterConfig = {

"EncodeType"           : "GB2312"

, "Company"                : "荆门泽优软件有限公司"

, "Version"                : "1,5,131,51655"

, "License2": ""

, "Debug"              : false//调试模式

, "LogFile"                : "f:\\log.txt"//日志文件路径

, "PasteWordType"      : ""//粘贴WORD的图片格式。JPG/PNG/GIF/BMP,推荐使用JPG格式,防止出现大图片。

, "PasteImageType"    : ""//粘贴文件,剪帖板的图片格式,为空表示本地图片格式。JPG/PNG/GIF/BMP

, "PasteImgSrc"            : ""//shape:优先使用源公式图片,img:使用word自动生成的图片

, "JpgQuality"         : "100"   //JPG质量。0~100

, "QueueCount"             : "5"//同时上传线程数

, "CryptoType"             : "crc"//名称计算方式,md5,crc,sha1,uuid,其中uuid为随机名称

, "ThumbWidth"             : "0"//缩略图宽度。0表示不使用缩略图

, "ThumbHeight"            : "0"//缩略图高度。0表示不使用缩略图

, "FileFieldName"      : "file"//自定义文件名称名称

, "ImageMatch"         : ""//服务器返回数据匹配模式,正则表达式,提取括号中的地址

, "FormulaDraw"             : "gdi"//公式图片绘制器,gdi,magick

, "AppPath"                 : ""

, "Cookie"                 : ""

, "Servers"             :[{"url":"www.ncmem.com"},{"url":"www.xproerui.com"}]//内部服务器地址(不下载此地址中的图片)

, "IcoError"            : "http://www.ncmem.com/products/word-imagepaster/ckeditor353/WordPaster/error.png"

, "IcoUploader"         : "http://www.ncmem.com/products/word-imagepaster/ckeditor353/WordPaster/upload.gif"

, "PostUrl"                : "http://www.ncmem.com/products/word-imagepaster/fckeditor2461/asp.net/upload.aspx"

//x86

, "ClsidParser"            : "2404399F-F06B-477F-B407-B8A5385D2C5E"

, "CabPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.cab"

//x64

, "ClsidParser64"      : "7C3DBFA4-DDE6-438A-BEEA-74920D90764B"

, "CabPath64"          : "http://www.ncmem.com/download/WordPaster2/WordPaster64.cab"

//Firefox

, "XpiType"               : "application/npWordPaster2"

, "XpiPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.xpi"

//Chrome

, "CrxName"                : "npWordPaster2"

, "CrxType"               : "application/npWordPaster2"

, "CrxPath"                : "http://www.ncmem.com/download/WordPaster2/WordPaster.crx"

//Edge

, edge: { protocol: "wordpaster", port: 9200, visible: false }

, "ExePath": "http://www.ncmem.com/download/WordPaster2/WordPaster.exe"

, "mac": {path: "http://www.ncmem.com/download/WordPaster2/WordPaster.exe"}

};

3、官方刚发表新版本说已经添加功能:

ckeditor编辑器批量上传的效果

图片已经上传到服务器端

图片地址已经替换过来了

可以看得出来,效果和用户体验都非常好。用户借助于此功能编辑功能得到大幅度提升了。

详细配置信息可以参考这篇文章:http://blog.ncmem.com/wordpress/2019/10/19/ckeditor%e7%9b%b4%e6%8e%a5%e7%b2%98%e8%b4%b4%e5%9b%be%e7%89%87%e5%ae%9e%e7%8e%b0/

最新文章

  1. Greenplum记录(一):主体结构、master、segments节点、interconnect、performance monitor
  2. ipod中,写计时器倒计时界面倒计时没有更改
  3. Writable、WritableComparable和comparators
  4. javaSE第二天
  5. Flipping Parentheses(CSU1542 线段树)
  6. Linux下通过ioctl系统调用来获取和设置网络信息
  7. 微软云平台windows azure入门系列八课程
  8. Java开发十大常用网站
  9. DES加密与解密在GET请求时解密失败的问题
  10. Find the Celebrity 解答
  11. Attempted to lock an already-locked dir异常解决方法
  12. centOS7 mini配置linux服务器(四) 配置jdk
  13. 【转载】LINUX上MYSQL优化三板斧
  14. Java使用Jedis操作Redis大全
  15. 聚类——WKFCM
  16. C# 托管内存与非托管内存之间的转换
  17. linux系统上次启动时间查看
  18. ICDAR2015 数据处理及训练
  19. 如何利用 AVDictionary 配置参数(转)
  20. redis连接被拒绝

热门文章

  1. 【SD系列】SAP SD凭证处理被批次处理冻结
  2. bzoj3028食物 关于(1+x+x2+x3+x4+...)^k的第i项系数就是c(i+k−1,k−1)的证明
  3. [每天一课] 今天就讲一讲关于vue-cli 脚手架里 如何调用API
  4. Git 的使用及其一些基本用法
  5. 第三章 四大组件之Activity(一)生命周期
  6. 2016青岛区域赛.Coding Contest(费用流 + 概率计算转换为加法计算)
  7. 正斜杠"/"与反斜杠"\"
  8. kotlin学习(6)运算符重载和其他约定
  9. js模拟自动化测试 -- 多用户登录
  10. 分布式事务中的2PC和3PC