Spring Boot项目百度UEditor上传图片

2024-03-28 04:32

本文主要是介绍Spring Boot项目百度UEditor上传图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

业务背景

  • spring boot项目
  • 实现富文本框
  • 上传图片到富文本框中,可新增、编辑
  • 图片保存在独立的FastDFS服务器上

开发步骤

下载源码

  • UEditor官网下载地址
  • 我下载的版本是【1.4.3.3 Jsp 版本】UTF-8版

将源码放到项目指定位置

  • 示例如下
    这里写图片描述

加入指定JAR依赖

  • 具体JAR在 \ueditor\jsp\lib 下
  • POM文件中示例【即ueditor-1.1.2.jar】
<dependency><groupId>cn.songxinqiang</groupId><artifactId>com.baidu.ueditor</artifactId><version>1.1.2-offical</version>
</dependency>

源码重要介绍

  • ueditor/ueditor.config.js
    这里写图片描述

  • /ueditor/jsp/config.json
    这里写图片描述

  • ueditor/jsp/controller.jsp
    这里写图片描述

后端请求规范

  • 文档详情

  • 图片上传完成时,为使得图片在富文本框中成功回显,上传方法返回的JSON数据格式必须和官方文档规定的保持一致,格式如下

{"state": "SUCCESS","url": "upload/demo.jpg","title": "demo.jpg","original": "demo.jpg"
}

覆盖默认的请求地址

action的配置对应【 /ueditor/jsp/config.json】中的 “imageActionName”: “uploadimage”, /* 执行上传图片的action名称 */

UE.Editor.prototype._bkGetActionUrl = UE.Editor.prototype.getActionUrl;
UE.Editor.prototype.getActionUrl = function(action) {// 这里很重要,很重要,很重要,要和配置中的imageActionName值一样if (action == 'uploadimage') { // 这里调用后端我们写的图片上传接口return 'commonQuestionsQuery/uploadImageData';} else {return this._bkGetActionUrl.call(this, action);}
} 

后台代码

  • 类UeditorImage源码
package com.sto.customerapp.entity;public class UeditorImage {private String state; private String url; private String title; private String original; public String getState() {return state;}public void setState(String state) {this.state = state;}public String getUrl() {return url;}public void setUrl(String url) {this.url = url;}public String getTitle() {return title;}public void setTitle(String title) {this.title = title;}public String getOriginal() {return original;}public void setOriginal(String original) {this.original = original;}}
  • Handler中源码
@RequestMapping("/uploadImageData")
@ResponseBody
public String uploadImageData(HttpServletRequest request) {Gson gson = new Gson();UeditorImage msg = uploadFile(request);return gson.toJson(msg);
}private UeditorImage uploadFile(HttpServletRequest request) {UeditorImage image = new UeditorImage();List<MultipartFile> files = ((MultipartHttpServletRequest) request).getFiles("upfile");try {String fileName = files.get(0).getOriginalFilename();logger.info("接收到上传数据,图片名称为 :" + fileName);String path = fastdfsClient.uploadFile(files.get(0), "", false);logger.info("图片上传成功,上传路径为 :" + serverPath + path);image.setUrl(serverPath + path);image.setState("SUCCESS");image.setOriginal(fileName);image.setTitle(fileName);} catch (IOException e) {e.printStackTrace();logger.error("图片上传失败,失败原因:" + e.getMessage());image.setState("FAIL");}return image;
}

这篇关于Spring Boot项目百度UEditor上传图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/854457

相关文章

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma