IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> iceEditor富文本上传图片,后台接口如何用java实现 -> 正文阅读

[Java知识库]iceEditor富文本上传图片,后台接口如何用java实现

package ********;
import org.apache.catalina.servlet4preview.http.HttpServletRequest;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;

import java.io.File;
import java.util.*;
/**
 * 文件上传
 * @author 欢小仙
 * @Date 2022/4/8
 */
@Controller
@RequestMapping("/file")
public class FileUploadController {
    /**
     * html代码 :
     *     略
     * js 代码:
     * <script>
     *   var e= new ice.editor("content",function(e){
     *    e.uploadUrl='http://127.0.0.1:8081/file/layeditUploadText';
     *      e.create();
     * })
     * script>
     *      
     * java 
     * 代码:     
     *      看过大佬写的iceEditor.js源码相信相信小伙伴对这个组件了解的七七八八了吧,
     *       这个组件很牛就不用说了吧
     * 分析:     
     *       实现图片上传,我们需要知道前端给后端传什么参数,无非就俩种情况
     *       1.File 对象 2.MultipartFile 对象
     *       当前端请求接口时候前端会把这俩个当作请求参数发给我们,我们后台获取到就可以了
     *  操作:
     *      1.后台通过@RequestParam("file[]") MultipartFile[] pictures 接到MultipartFile对象然后通过IO流实现文件读写即可
     *        建议大家多看一下大佬的iceEditor.js源码 中的1029-1069   特别是1039行代码  89-94 变量的初始化
     *       1067行就是通过ajax 发送请求 ,也就是我们在js中先初始化组件在设置请求访问接口的路径e.uploadUrl='http://127.0.0.1:8081/file/layeditUploadText';
     *      2.将拿到的图片通过UUID重新生成名字,以防止名字重复
     *      3.ToolUtil.getFileSuffix() 自己写了一个工具类就是去后缀名而已
     *      4.ROOT_PATH、PUBLIC_PATH  这是我在yml在取得一些配置(就是路径)大家可以根据自己的来写
     *      5.按照大佬的说法最后返回一个包含属性error、url、name的集合就可以实现图片上传了
     *  优化:
     *      我没有添加一些健壮性判断,比如图片太大导致出现的一些异常,等等
     **/
@Value("${guns.file-upload-path}")
private String ROOT_PATH;
@Value("${guns.file-upload-path-public}")
private String PUBLIC_PATH;


@RequestMapping("/layeditUploadText")
@ResponseBody
public List> fileUpload(HttpServletRequest request, @RequestParam("file[]") MultipartFile[] pictures) {
        List> lists = new ArrayList>();
        String [] arr=new String[pictures.length];
        for(int a=0;alength;a++){
        arr[a] = UUID.randomUUID().toString() + "." + ToolUtil.getFileSuffix(pictures[a].getOriginalFilename());
        }
        //创建文件夹生成地点
        File dir = new File(ROOT_PATH+PUBLIC_PATH);
        if(!dir.exists()) {
        dir.mkdirs();
        }
        //将文件通过io流写写入指定磁盘位置或者服务器中
        try {
        for(int a=0;alength;a++){
        pictures[a].transferTo(new File(dir+"/"+arr[a]));
        //创建返回响应对象
        Map map=new HashMap<>();
        map.put("error",0);
        map.put("url",PUBLIC_PATH+"/"+arr[a]);
        map.put("name",arr[a]);
        lists.add(map);
        }
        } catch (Exception e) {
        throw new GunsException(BizExceptionEnum.UPLOAD_ERROR);
        }
        return lists;
        }
   }
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:09:53  更:2022-04-09 18:12:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 6:02:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码