MarkDown提取文本作为文章简介
这几乎是所有使用md的博客项目需要使用到的技术,但是提取文本不是万能的,所以文章头部最好放一些简介或者md的纯文本内容之内的,不建议放代码块/链接/奇怪符号。
效果图(如不不实用本文的提取方法,通常开头就是几个#### 看着很丑陋)

实现原理
首先使用依赖将md转为html,然后通过正则表达式去掉标签
- 导入依赖
 
<!--markdown转html-->
        <dependency>
            <groupId>org.pegdown</groupId>
            <artifactId>pegdown</artifactId>
            <version>1.6.0</version>
        </dependency>
- 实现工具类
 
import org.pegdown.PegDownProcessor;
/** * @author MinXu * @since 2021/5/18 * QQ 754647431 */
public class MDToText { 
    /** * 去除html代码中含有的标签 * @param htmlStr * @return */
    private static String delHtmlTags(String htmlStr) { 
        //定义script的正则表达式,去除js可以防止注入
        String scriptRegex="<script[^>]*?>[\\s\\S]*?<\\/script>";
        //定义style的正则表达式,去除style样式,防止css代码过多时只截取到css样式代码
        String styleRegex="<style[^>]*?>[\\s\\S]*?<\\/style>";
        //定义HTML标签的正则表达式,去除标签,只提取文字内容
        String htmlRegex="<[^>]+>";
        //定义空格,回车,换行符,制表符
        String spaceRegex = "\\s*|\t|\r|\n";
        // 过滤script标签
        htmlStr = htmlStr.replaceAll(scriptRegex, "");
        // 过滤style标签
        htmlStr = htmlStr.replaceAll(styleRegex, "");
        // 过滤html标签
        htmlStr = htmlStr.replaceAll(htmlRegex, "");
        // 过滤空格等
        htmlStr = htmlStr.replaceAll(spaceRegex, "");
        return htmlStr.trim(); // 返回文本字符串
    }
    /** * 获取HTML代码里的内容 * @param htmlStr * @return */
    private static String getTextFromHtml(String htmlStr){ 
        //去除html标签
        htmlStr = delHtmlTags(htmlStr);
        //去除空格" "
        htmlStr = htmlStr.replaceAll(" ","");
        return htmlStr;
    }
    public static String mdToText(String mdContent){ 
        PegDownProcessor pdp = new PegDownProcessor(Integer.MAX_VALUE);
        String htmlContent = pdp.markdownToHtml(mdContent);
        return getTextFromHtml(htmlContent);
    }
}
原文链接:https://blog.csdn.net/qq_45117655/article/details/117002223























