ueditor富文本编辑器实现上传图片到7牛图片服务器

直接上代码:

js:$(function(){
    //富文本编辑器
    var ue = UE.getEditor("myEditor");
    //百度文本编辑器上传图片
    UE.Editor.prototype._bkGetActionUrl = UE.Editor.prototype.getActionUrl;
    UE.Editor.prototype.getActionUrl = function(action) {
        if (action == 'uploadimage' || action == 'uploadscrawl' || action == 'uploadimage') {
            return '/imageUpload/upload.do';
        }else {
            return this._bkGetActionUrl.call(this, action);
        }
    }
});

2.配置config.json

3.action:

package com.antke.website.action;

import java.io.IOException;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import com.antke.website.utils.ImageUploadUtil;
import com.antke.website.utils.qiniuUtil;
@Controller
@RequestMapping("/imageUpload")
public class ImageUploadAction {

    
     @RequestMapping("/upload.do")
     public void imageUpload(HttpServletRequest request, HttpServletResponse response){
         String DirectoryName = "upload/";
            try {
                ImageUploadUtil.ckeditor(request, response, DirectoryName);
            } catch (IllegalStateException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
     }
}
3.工具类

package com.antke.website.utils;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.json.JSONException;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartResolver;

import com.thoughtworks.xstream.core.util.Base64Encoder;

public class ImageUploadUtil {
     // 图片类型
    private static List<String> fileTypes = new ArrayList<String>();

    static {
        fileTypes.add(".jpg");
        fileTypes.add(".jpeg");
        fileTypes.add(".bmp");
        fileTypes.add(".gif");
        fileTypes.add(".png");
    }
    
    /**
     * 图片上传
     * 
     * @Title upload
     * @param request
     * @param DirectoryName
     *            文件上传目录:比如upload(无需带前面的/) upload/news ..
     * @return
     * @throws IllegalStateException
     * @throws IOException
     */
    public static String upload(HttpServletRequest request,HttpServletResponse response, String DirectoryName) throws IllegalStateException,
            IOException {
        PrintWriter out = null;
        response.setContentType("text/html");     
        response.setCharacterEncoding("UTF-8");  
        response.setContentType("multipart/form-data");
        
        // 创建一个通用的多部分解析器
        CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(request.getSession()
                .getServletContext());
        // 图片名称
        String fileName = null;
        // 判断 request 是否有文件上传,即多部分请求
        if (multipartResolver.isMultipart(request)) {
            // 转换成多部分request
            MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request;
            // 取得request中的所有文件名
            Iterator<String> iter = multiRequest.getFileNames();
            while (iter.hasNext()) {
                // 记录上传过程起始时的时间,用来计算上传时间
                // int pre = (int) System.currentTimeMillis();
                // 取得上传文件
                MultipartFile file = multiRequest.getFile(iter.next());
                if (file != null) {
                    try {
                        Base64Encoder encoder = new Base64Encoder();
                        String img = encoder.encode(file.getBytes());
                        Map responMap = new HashMap();
                        Map rsMap = qiniuUtil.upload(Base64.decode(img));
                        responMap.put("image_url", rsMap.get("image_url"));
                        fileName = (String) rsMap.get("image_url");
                        /*String json = JacksonUtil.convertData(responMap,"2");
                        fileName = json;*/
                        /*String json = JacksonUtil.convertData(responMap,"2");
                        response.setContentType("text/html;charset=UTF-8");
                        System.out.println(rsMap.get("image_url"));
                        out = response.getWriter();
                        out.println(json);
                        out.flush();
                        out.close();*/
                        
                        
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                    
                    
                    
                    // 取得当前上传文件的文件名称
                   /* String myFileName = file.getOriginalFilename();
                    // 如果名称不为“”,说明该文件存在,否则说明该文件不存在
                    if (myFileName.trim() != "") {
                        // 获得图片的原始名称
                        String originalFilename = file.getOriginalFilename();
                        // 获得图片后缀名称,如果后缀不为图片格式,则不上传
                        String suffix = originalFilename.substring(originalFilename.lastIndexOf(".")).toLowerCase();
                        if (!fileTypes.contains(suffix)) {
                            continue;
                        }
                        // 获得上传路径的绝对路径地址(/upload)-->
                        String realPath = request.getSession().getServletContext().getRealPath("/" + DirectoryName);
                        System.out.println(realPath);
                        // 如果路径不存在,则创建该路径
                        File realPathDirectory = new File(realPath);
                        if (realPathDirectory == null || !realPathDirectory.exists()) {
                            realPathDirectory.mkdirs();
                        }
                        // 重命名上传后的文件名 111112323.jpg
                        fileName = DateUtil.format(new Date(), "yyyy-MM-dd") + suffix;
                        // 定义上传路径 .../upload/111112323.jpg
                        File uploadFile = new File(realPathDirectory + "\\" + fileName);
                        System.out.println(uploadFile);
                        file.transferTo(uploadFile);
                    }*/
                }
                // 记录上传该文件后的时间
                // int finaltime = (int) System.currentTimeMillis();
                // System.out.println(finaltime - pre);
            }
        }
        return fileName;
    }

    /**
     * ckeditor文件上传功能,回调,传回图片路径,实现预览效果。
     * 
     * @Title ckeditor
     * @param request
     * @param response
     * @param DirectoryName
     *            文件上传目录:比如upload(无需带前面的/) upload/..
     * @throws IOException
     */
    public static void ckeditor(HttpServletRequest request, HttpServletResponse response, String DirectoryName)
            throws IOException {
        String fileNamePath = upload(request,response, DirectoryName);
        String[] split = fileNamePath.split("/");
        String fileName = split[3];
        
        // 结合ckeditor功能
        // imageContextPath为图片在服务器地址,如upload/123.jpg,非绝对路径
        //String imageContextPath = request.getContextPath() + "/" + DirectoryName + "/" + fileName;
        
        response.setContentType("text/html;charset=UTF-8");
        String callback = request.getParameter("CKEditorFuncNum");
        PrintWriter out = response.getWriter();
        
        
        String json = "{ \"state\": \"SUCCESS\",\"url\": \""+fileName+"\"}";
        
        out.println(json);
        /*out.println("<script type=\"text/javascript\">");
        out.println("window.parent.CKEDITOR.tools.callFunction(" + 0 + ",'" + fileNamePath + "',''" + ")");
//        out.println("<img src='"+fileNamePath+"' />");
        out.println("</script>");*/
        out.flush();
        out.close();
    }

}
 

猜你喜欢

转载自blog.csdn.net/NB6063/article/details/82561986