Markdown纯后端解析,CommonMark和Flexmark的基本使用

前言

最近在做个人博客网站 云仔☁笔记,碰到了问题,怎样将Markdown文档解析后显示在页面中,因为前端只会基础,所以想着通过纯后端实现文档解析,通过查询资料我找到了两个办法:

  • 方法一:CommonMark
  • 方法二:Flexmark

以上两个方法,均可以将Markdown文档解析为HTML代码

CommonMark-java

文档阅读:CommonMark-java --GitHub仓库

1. 介绍

CommonMark是一个规范,定义了一种简洁、一致的 Markdown 格式语法。它旨在提供一种标准的方式来解析和渲染 Markdown 文档。

2. 使用教程

  • 引入Maven依赖
    • commonmark-ext-gfm-tables:用来实现表格的解析的依赖
		<dependency>
            <groupId>org.commonmark</groupId>
            <artifactId>commonmark</artifactId>
            <version>0.20.0</version>
        </dependency>
        <!-- 实现表格解析 -->
        <dependency>
            <groupId>org.commonmark</groupId>
            <artifactId>commonmark-ext-gfm-tables</artifactId>
            <version>0.20.0</version>
        </dependency>
  • JAVA代码示例
	public static String parseMarkdownCommonmark(String markdownContent) {
        //解析表格
        List<Extension> extensions = Arrays.asList(TablesExtension.create());
        org.commonmark.parser.Parser parser = org.commonmark.parser.Parser.builder().extensions(extensions).build();
        Node document = parser.parse(markdownContent);
        org.commonmark.renderer.html.HtmlRenderer renderer = org.commonmark.renderer.html.HtmlRenderer.builder().extensions(extensions).build();
        
        return renderer.render(document);
    }

3. 问题

无法实现目录的解析,也就是Markdown文档中的[TOC],当然Flexmark很好的解决了这个问题

Flexmark-java

官方文档阅读:Flexmark-java --GitHub仓库

1. 介绍

Flexmark-Java是一个基于 CommonMark 规范的 Java 库,用于解析和渲染 Markdown 文档。它提供了一个灵活的、易于使用的 API,可以自定义解析和渲染的行为。

2. 使用示例

  • 引入Maven依赖

    • 最新版本为0.64.8,支持java11及更高,不支持java8
            <dependency>
                <groupId>com.vladsch.flexmark</groupId>
                <artifactId>flexmark-all</artifactId>
                <version>0.62.2</version>
                <scope>compile</scope>
            </dependency>
    
  • java代码

    public static String parseMarkdownFlexmark(String markdown) {
            MutableDataSet options = new MutableDataSet();
        	//TOC目录解析,表格解析
            options.set(Parser.EXTENSIONS, Arrays.asList(TocExtension.create(), TablesExtension.create()));
    
            Parser parser = Parser.builder(options).build();
            Document document = parser.parse(markdown);
    
            HtmlRenderer renderer = HtmlRenderer.builder(options).build();
    
            return renderer.render(document);
        }
    

总结

以上两种方法很好的解决了Markdown文档在后端解析为HTML文档的需求

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值