引用MarkDown編輯器

下載插件:
http://pandao.github.io/editor.md/

將下載的插件解壓拷貝進(jìn)項(xiàng)目中

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<link rel="stylesheet" href="${pageContext.request.contextPath}/res/editor-md-master/css/editormd.css" />
<script type="text/javascript" src="${ pageContext.request.contextPath }/res/js/jquery-2.1.4.min.js"></script>
<script src="${pageContext.request.contextPath}/res/editor-md-master/editormd.min.js"></script>
<script type="text/javascript">
    $(function(){
        var testEditor = editormd({
            id: "test-editormd",
            height: 640,
            width: "100%",
            placeholder : "Markdown編輯器",
            path: "${pageContext.request.contextPath}/res/editor-md-master/lib/",
            toolbarIcons: function () {
                // Or return editormd.toolbarModes[name]; // full, simple, mini
                // Using "||" set icons align right.
                return ["undo", "redo", "|", "watch", "fullscreen", "preview"]
            },
            //toolbar  : false,             // 關(guān)閉工具欄
            codeFold: true,
            searchReplace: true,
            saveHTMLToTextarea: true,      // 保存 HTML 到 Textarea
            htmlDecode: "style,script,iframe|on*",            // 開(kāi)啟 HTML 標(biāo)簽解析局劲,為了安全性锭汛,默認(rèn)不開(kāi)啟
            emoji: true,
            taskList: true,
            tocm: true,          // Using [TOCM]
            tex: true,                      // 開(kāi)啟科學(xué)公式 TeX 語(yǔ)言支持邮辽,默認(rèn)關(guān)閉
            //previewCodeHighlight : false,  // 關(guān)閉預(yù)覽窗口的代碼高亮,默認(rèn)開(kāi)啟
            flowChart: true,                // 疑似 Sea.js與 Raphael.js 有沖突迎献,必須先加載 Raphael.js 改备,Editor.md 才能在 Sea.js 下正常進(jìn)行婴梧;
            sequenceDiagram: true,          // 同上
            //dialogLockScreen : false,      // 設(shè)置彈出層對(duì)話框不鎖屏穗椅,全局通用辨绊,默認(rèn)為 true
            //dialogShowMask : false,     // 設(shè)置彈出層對(duì)話框顯示透明遮罩層,全局通用匹表,默認(rèn)為 true
            //dialogDraggable : false,    // 設(shè)置彈出層對(duì)話框不可拖動(dòng)门坷,全局通用宣鄙,默認(rèn)為 true
            //dialogMaskOpacity : 0.4,    // 設(shè)置透明遮罩層的透明度,全局通用默蚌,默認(rèn)值為 0.1
            //dialogMaskBgColor : "#000", // 設(shè)置透明遮罩層的背景顏色冻晤,全局通用,默認(rèn)為 #fff
            imageUpload: true,
            imageFormats: ["jpg", "jpeg", "gif", "png", "bmp", "webp"],
            imageUploadURL: "{:url('api/uploader/uploadEditorImg?pic_type=10')}",
            onload: function () {
                this.on('paste', function () {
                    console.log(1);
                });
            },
            onpreviewing : function() {
                this.watch();
                console.log("onpreviewing =>", this, this.id, this.settings);
                // on previewing you can custom css .editormd-preview-active
            },
            onpreviewed : function() {
                console.log("onpreviewed =>", this, this.id, this.settings);
                this.unwatch();
            }
        });
        
        
        /**
         * 上傳圖片
         */
        $("#test-editormd").on('paste', function (ev) {
            var data = ev.clipboardData;
            var items = (event.clipboardData || event.originalEvent.clipboardData).items;
            for (var index in items) {
                var item = items[index];
                if (item.kind === 'file') {
                    var blob = item.getAsFile();
                    var reader = new FileReader();
                    reader.onload = function (event) {
                        var base64 = event.target.result;
                        console.log(base64);
                        //ajax上傳圖片
                        $.ajax({
                            url : "${pageContext.request.contextPath}/topic/uploadimg",
                            type : 'post',
                            data : {'base':base64},
                            async : true,
                            dataType: 'json',
                            success : function (res) {
                                if (res.code === 1) {
                                    //新一行的圖片顯示
                                    testEditor.insertValue("\n![" + "image.png" + "](${pageContext.request.contextPath}/" + res.path + ")");
                                }
                            },
                            error : function(){
                                alert('圖片上傳錯(cuò)誤');
                            }
                        });
                    }; // data url!
                    var url = reader.readAsDataURL(blob);
                }
            }
        });
    })
</script>
</head>
<body>
    <form action="${ pageContext.request.contextPath }/article/addArticle">
        <div class="editormd" id="test-editormd">
            <textarea class="editormd-markdown-textarea" name="topic_markdown_content" id = "topic_markdown_content">${topic.topic_markdown_content}</textarea>
        </div>
        <button>提交</button>
    </form>
</body>
</html>

解密后保存工具類

package com.neuedu.util;

import java.io.FileOutputStream;
import java.io.OutputStream;

import sun.misc.BASE64Decoder;

public class picEncode {
    /**
     * @Description: 將base64編碼字符串轉(zhuǎn)換為圖片
     * @Author:
     * @CreateTime:
     * @param imgStr
     *            base64編碼字符串
     * @param path
     *            圖片路徑-具體到文件
     * @return
     */
    public static boolean generateImage(String imgStr, String path) {
        if (imgStr == null)
            return false;
        BASE64Decoder decoder = new BASE64Decoder();
        try {
            // 解密
            byte[] b = decoder.decodeBuffer(imgStr);
            // 處理數(shù)據(jù)
            for (int i = 0; i < b.length; ++i) {
                if (b[i] < 0) {
                    b[i] += 256;
                }
            }
            OutputStream out = new FileOutputStream(path);
            out.write(b);
            out.flush();
            out.close();
            return true;
        } catch (Exception e) {
            return false;
        }
    }
}

實(shí)體類绸吸,用來(lái)響應(yīng)頁(yè)面請(qǐng)求

package com.neuedu.util;

public class imgUploadBackData {
    private String path;
    private int code;

    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }

    public String getPath() {
        return path;
    }

    public void setPath(String path) {
        this.path = path;
    }
}

Controller或Servlet

package com.neuedu.servlet;

import java.io.File;
import java.io.IOException;
import java.util.UUID;

import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.alibaba.fastjson.JSON;
import com.neuedu.util.imgUploadBackData;
import com.neuedu.util.picEncode;

@WebServlet("/topic/uploadimg")
public class UploadImgServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String strTemp = request.getParameter("base");
        System.out.println(strTemp);
        strTemp = strTemp.replace("data:image/png;base64,","");
//        String strPath = this.getClass().getClassLoader().getResource("/../../upload").getPath();
        String strPath = request.getServletContext().getRealPath(File.separator+"upload");
        String strUUid = UUID.randomUUID().toString();
        System.out.println(strPath);
        File file = new File(strPath);
        if(!file.exists())
        {
            file.mkdirs();
        }
        String strSavePath = strPath+File.separator+strUUid+".jpg";
        picEncode.generateImage(strTemp,strSavePath);
        imgUploadBackData iubd = new imgUploadBackData();
        iubd.setPath("upload"+File.separator+strUUid+".jpg");
        iubd.setCode(1);
        String strJson = JSON.toJSONString(iubd);
        response.getWriter().println(strJson);
    }
}

提交表單時(shí)可以觀察請(qǐng)求體中的參數(shù)鼻弧,會(huì)發(fā)現(xiàn)內(nèi)容包含兩部分,一部分是markdown語(yǔ)法部分惯裕,方便發(fā)布者修改文章温数,還有一部分是markdown渲染出的html部分绣硝,是作為展示的蜻势,所以,對(duì)應(yīng)數(shù)據(jù)庫(kù)中應(yīng)該也有兩個(gè)字段支持鹉胖。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末握玛,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子甫菠,更是在濱河造成了極大的恐慌挠铲,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件寂诱,死亡現(xiàn)場(chǎng)離奇詭異拂苹,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)痰洒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)瓢棒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人丘喻,你說(shuō)我怎么就攤上這事脯宿。” “怎么了泉粉?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵连霉,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我嗡靡,道長(zhǎng)跺撼,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任讨彼,我火速辦了婚禮歉井,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘点骑。我一直安慰自己酣难,他們只是感情好谍夭,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著憨募,像睡著了一般紧索。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上菜谣,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天珠漂,我揣著相機(jī)與錄音,去河邊找鬼尾膊。 笑死媳危,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的冈敛。 我是一名探鬼主播待笑,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼抓谴!你這毒婦竟也來(lái)了暮蹂?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤癌压,失蹤者是張志新(化名)和其女友劉穎仰泻,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體滩届,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡集侯,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了帜消。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棠枉。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖券犁,靈堂內(nèi)的尸體忽然破棺而出术健,到底是詐尸還是另有隱情,我是刑警寧澤粘衬,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布荞估,位于F島的核電站,受9級(jí)特大地震影響稚新,放射性物質(zhì)發(fā)生泄漏勘伺。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一褂删、第九天 我趴在偏房一處隱蔽的房頂上張望飞醉。 院中可真熱鬧,春花似錦、人聲如沸缅帘。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)钦无。三九已至逗栽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間失暂,已是汗流浹背彼宠。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留弟塞,地道東北人凭峡。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像决记,于是被迫代替她去往敵國(guó)和親摧冀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容