JS部分:
$('.summernote').summernote({
height: 200,//高度
tabsize: 2,//页面上的summernote编辑框的个数
lang: 'zh-CN',//语言
callbacks:{//回调函数,重写onImageUpload方法
onImageUpload: function(files, editor, welEditable) {
sendFile(this,files[0],editor,welEditable);
}
}
});
function sendFile(val,files,editor,welEditable) {
data = new FormData();
data.append("files", files);
$.ajax({
data: data,
dataType: 'json',
type: "POST",
url: "后台url",
cache: false,
contentType: false,
processData: false,
responseType: "json",
success: function(data) {
$(val).summernote('editor.insertImage', data.path);
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.readyState);
alert(textStatus);
}
});
} springmvc后台:
@RequestMapping(value = "ajaxUploadFile",produces="application/json;charset=UTF-8")
@ResponseBody
public void ajaxUploadFile(@RequestParam("files") CommonsMultipartFile myfiles, HttpServletRequest request,HttpServletResponse response) { int size = 0;
String fileLogicName = "";
PageData pageData = new PageData();
UUID uuid = UUID.randomUUID();
String[] fileNames = myfiles.getOriginalFilename().split("\\.");
String suffix = fileNames[1];
String fileName = uuid.toString().replace("-", ""); // 文件重命名
if (fileNames.length >= 2) {
fileName += "." + fileNames[1];
} String relPath = FilePathUtil.getUploadTempPath(request) + fileName;
String filePath = FilePathUtil.getFileRootPath(request) + relPath;// 文件保存的实际路径
File localFile = new File(filePath);
if (!localFile.getParentFile().exists()) {
localFile.getParentFile().mkdirs();
} try {
size = myfiles.getBytes().length;
fileLogicName = myfiles.getOriginalFilename();
myfiles.transferTo(localFile); // 保存文件
} catch (IOException e) {
pageData.setResult(2);
pageData.setDesc("上传文件失败");
logger.error("上传文件失败", e);
}
relPath = relPath.replace("\\", "/").replace("//", "/"); pageData.setResult(1);
pageData.setDesc("文件添加成功!");
relPath = relPath.replace("\\", "/").replace("//", "/");
FileInfo fileInfo = new FileInfo();
fileInfo.setFileSize(size);
fileInfo.setFileName(fileName);
fileInfo.setFilePath(relPath);
fileInfo.setSuffix(suffix);
fileInfo.setFullFileUrl(relPath);
fileInfo.setFileLogicName(fileLogicName);
StringBuffer stringBuffer = new StringBuffer();
stringBuffer.append("{");
stringBuffer.append("\"result\"" + ":" + "\"" + pageData.getResult() + "\",");
stringBuffer.append("\"desc\"" + ":" + "\"" + pageData.getDesc() + "\",");
stringBuffer.append("\"fileSize\"" + ":" + "\"" + fileInfo.getFileSize() + "\",");
stringBuffer.append("\"fileName\"" + ":" + "\"" + fileInfo.getFileName() + "\",");
stringBuffer.append("\"filePath\"" + ":" + "\"" + fileInfo.getFilePath() + "\",");
stringBuffer.append("\"suffix\"" + ":" + "\"" + fileInfo.getSuffix() + "\",");
stringBuffer.append("\"fullFileUrl\"" + ":" + "\"" + fileInfo.getFullFileUrl() + "\",");
stringBuffer.append("\"fileLogicName\"" + ":" + "\"" + fileInfo.getFileLogicName() + "\"");
stringBuffer.append("}");
try {
//response.setContentType("text/javascript");
response.setContentType("text/html; charset=utf-8");
response.getWriter().print(stringBuffer.toString());
} catch (IOException e) { }
} FileInfo实体类
package com.cec.test;
public class FileInfo { private Integer fileSize; private String fileName; private String filePath; private String suffix; private String fullFileUrl; private String fileLogicName; public Integer getFileSize() {
return fileSize;
} public void setFileSize(Integer fileSize) {
this.fileSize = fileSize;
} public String getFileName() {
return fileName;
} public void setFileName(String fileName) {
this.fileName = fileName;
} public String getFilePath() {
return filePath;
} public void setFilePath(String filePath) {
this.filePath = filePath;
} public String getSuffix() {
return suffix;
} public void setSuffix(String suffix) {
this.suffix = suffix;
} public String getFullFileUrl() {
return fullFileUrl;
} public void setFullFileUrl(String fullFileUrl) {
this.fullFileUrl = fullFileUrl;
} public String getFileLogicName() {
return fileLogicName;
} public void setFileLogicName(String fileLogicName) {
this.fileLogicName = fileLogicName;
}
} FilePathUtil工具类
public static String  getUploadTempPath(HttpServletRequest request){

    String currentDateStr = DateUtil.sdfDays.format(new Date());
StringBuffer downloadPath = new StringBuffer();
downloadPath.append( File.separator).append(FILE_UPLOAD_TEMP_PATH)
.append(File.separator).append(currentDateStr)
.append(File.separator);
// 解决掉前台jsp展示的时候出现 转义字符问题
String filepath = downloadPath.toString().replace("\\", "/").replace("//","/"); return filepath;
}
public static String getRelPath(HttpServletRequest request, String path){
String filepath = new StringBuffer (getFileRootPath(request)).append(path).toString();
filepath = filepath.toString().replace("\\", "/").replace("//","/");
File dir = new File(filepath);
if (!dir.exists()) {
boolean makeSucess = dir.mkdirs();
if(!makeSucess){
logger.error("创建文件目录失败:" + filepath);
}
}
return filepath;
}
//PageDate类 
//用于后台向前台响应ajax请求返回的对象
@Component
public class PageData {
private int result;
private Map<Object,Object> resultMap;
private String desc; public int getResult() {
return result;
} public void setResult(int result) {
this.result = result;
} public Map<Object,Object> getResultMap() { //统一分配资源
if(resultMap == null){
resultMap = new HashMap<Object,Object>();
} return resultMap;
} public void setResultMap(Map resultMap) {
this.resultMap = resultMap;
} public String getDesc() {
return desc;
} public void setDesc(String desc) {
this.desc = desc;
}
}
展示:


//UUID类可上网百度获得,工作之后初次使用summernote的使用经验。

场景:公司项目是一个页面上有两个富文本编辑框,和一个保存按钮
解决思路:在用户点击图片按钮,上传图片的时候,调用回调函数,将图片通过FormData对象传到后台,后台将图片暂时保存到临时图片文件夹,返回临时图片地址。
前台接收到图片地址之后,将图片插入到富文本编辑框内。当用户点击保存时,将临时文件夹中的图片保存到真实图片保存目录下(这样做的目的是为了解决维护人员不会把临时文件删除掉,看个人需求)。
通过summernote('code')获取文本框内的内容,通过ajax传到后台,后台接收到参数之后,使用正则表达式替换掉临时文件夹的目录,最终返回真实图片保存目录,将真实图片保存目录保存到数据库。 //备注:解决思路中的保存步骤代码在此处没有展示。 总结:思路很重要,先理清思路,再动手不迟!

												

使用summernote编辑器上传图片,重写onImageUpload的更多相关文章

  1. 使用Ueditor编辑器上传图片总结;

    今天使用Ueditor编辑器上传图片一直出问题,在网上找了多种方法,最后总结如下: Ueditor编辑器是百度开发的编辑器,要在jsp页面添加Ueditor编辑器,需要以下几步: (1)到 http: ...

  2. 富文本编辑器上传图片需要配置js,后台代码

    富文本编辑器上传图片需要配置js,后台代码

  3. vue问题四:富文本编辑器上传图片

    vue使用富文本编辑器上传图片: 我是用的是wangEditor 富文本编辑器 demo:http://www.wangeditor.com/ 1).安装依赖:npm install wangedit ...

  4. tinymce 编辑器 上传图片

    tinymce编辑器进行本地图片上传 首先下载tinymce.js之后 在form中添加一个<textarea>元素 给其一个id和name 然后就可以初始化编辑器了 tinymce.in ...

  5. eWebeditor编辑器上传图片路径错误解决方法[疑难杂症]【转,作者:unvs】

    做了一个多版本的网站,后台用的编辑器是eWebeditor,NET版,后面发现上传图片或者文件之后,路径错误无法显示,必须手工修改才行.. 为了更清楚的说明问题,我下面会说的比较详细,首先是网站文件框 ...

  6. 在linux下使用百度ueditor编辑器上传图片

    百度ueditor编辑器虽然强大,但是也有不足的地方.如果对ueditor流程不是很熟悉可以说走的弯路比较多,费力不讨好.下面呢,就是要解决ueditor遇到的问题. 用ueditor上传图片遇到的问 ...

  7. xheditor编辑器上传图片

    之前在用csdn的时候,觉得他们家的编辑器挺好用,精美,简洁,大方,功能强大.最近自己的项目也要用到编辑器,我就想起了xheditor. 好多大网站都用到它~好棒! 我把xheditor用于文章模块, ...

  8. kindeditor编辑器上传图片

    使用的是asp.net MVC 上传图片. 1.下载Kindeditor的对应的包 2.html页面 @{ Layout = null; } <!DOCTYPE html> <htm ...

  9. C# Asp.net 修改Ueditor编辑器上传图片保存路径

    默认情况下Ueditor图片上传的保存路径是在/ueditor/net/upload/目录下,(如:http://localhost/ueditor/net/upload/123.png), 但是有时 ...

随机推荐

  1. 数据结构 Job

    问题描述 有 n 项工作在等待队列中等待处理,编号为 1-n. 每个工作有个优先级 p.处理机同一时间只能处理一项工作.处理机决定接下来处理哪一项工作的方式为:从队首取出一项工作 x,若等待队列中没有 ...

  2. js/jq基础(日常整理记录)-1-纯js格式化时间

    一.纯js格式化时间 之前记录了一些,工作中发现的比较常用的使用,就记录一下. 由于很基础,就直接贴出来了,不做分析了. 改造一下Date的原型 Date.prototype.format = fun ...

  3. 模仿添加QQ好友桌面快捷方式

    /** * * @param context * @param tname 桌面快捷方式的名字 * @param icon 好友头像 */ public static void addShortCut ...

  4. java 字符流 字节流

    java对文本文档进行操作(拷贝.显示)出现乱码一般来说,可以从两个方面入手. 1.文本文件本身的编码格式. 2.java代码中处理文本文件的编码格式. 这里要注意的一点是,我们可以看出copyFil ...

  5. js 代码收集

    //获取image src路径 $(".userImg").click(function(){ var imgsrc = $(this).attr("src") ...

  6. 实现基于dotnetcore的扫一扫登录功能

    第一次写博客,前几天看到.netcore的认证,就心血来潮想实现一下基于netcore的一个扫一扫的功能,实现思路构思大概是web端通过cookie认证进行授权,手机端通过jwt授权,web端登录界面 ...

  7. 访问其他电脑的c盘

    访问其他电脑的c盘 \\192.168.0.1\C$

  8. Note: Transparent data deduplication in the cloud

    What Design and implement ClearBox which allows a storage service provider to transparently attest t ...

  9. 洛谷P4173 残缺的字符串(FFT)

    传送门 话说为什么字符串会和卷积扯上关系呢……到底得脑洞大到什么程度才能想到这种东西啊……大佬太珂怕了…… 因为通配符的关系,自动机已经废了 那么换种方式考虑,如果两个字符串每一位对应的编码都相等,那 ...

  10. Shell-2-命令之乐

    1.cat (1)基本用法 [root@cai tmp]# cat 1.txt 2.txt this is a test1 this is a test 2 (2)cat -s file(删除额外空白 ...