基于Hutool实现自定义模板引擎,实现json个性化模板引擎转换

前言

由于百度搜索json模板引擎,推荐的都是一些freemarker之类的,需要引入其他的依赖,而且在编写json模板的时候使用${}进行格式化的时候会把{}当作json的格式进行格式化,导致json模板非常难看。
所以笔者基于hutool的TemplateUtil进行扩展,通过实现了TemplateEngine接口,CustomTemplate继承AbstractTemplate抽象类,来实现个性化的模板转换。
并且按照这样的写法,还可以自定义扩展其他的模板引擎格式,如${}$$#{}

编写引擎类:JsonTemplateEngine

package com.hx.core.jsonTemplate;

import cn.hutool.core.io.resource.ResourceUtil;
import cn.hutool.extra.template.Template;
import cn.hutool.extra.template.TemplateConfig;
import cn.hutool.extra.template.TemplateEngine;

/**
 * 自定义模板引擎——引擎类
 */
public class JsonTemplateEngine implements TemplateEngine {
    TemplateConfig cfg;

    private static final String PREFIX = "$";
    private static final String SUFFIX = "$";

    public JsonTemplateEngine() {
    }

    public JsonTemplateEngine(TemplateConfig cfg) {
        this.init(cfg);
    }

    @Override
    public TemplateEngine init(TemplateConfig config) {
        if (null == config) {
            config = TemplateConfig.DEFAULT;
        }
        this.cfg = config;
        return this;
    }

    @Override
    public Template getTemplate(String resource) {
        if (null == this.cfg) {
            this.init(TemplateConfig.DEFAULT);
        }
        StringBuilder stringBuilder = null;
        String path = this.cfg.getPath() + "\\" + resource;
        switch (this.cfg.getResourceMode()) {
            case CLASSPATH:
                stringBuilder = new StringBuilder(ResourceUtil.readStr(path, this.cfg.getCharset()));
                break;
            case FILE:
                stringBuilder = new StringBuilder(ResourceUtil.readStr(path, this.cfg.getCharset()));
                break;
            case WEB_ROOT:
                throw new RuntimeException("暂不支持的模板加载类型");
            case STRING:
                stringBuilder = new StringBuilder(resource);
                break;
            default:
                throw new RuntimeException("暂不支持的模板加载类型");
        }
        return new CustomTemplate(stringBuilder, PREFIX, SUFFIX);
    }

}

编写模板类:CustomTemplate

package com.hx.core.jsonTemplate;

import cn.hutool.core.util.StrUtil;
import cn.hutool.extra.template.AbstractTemplate;

import java.io.*;
import java.util.Map;

/**
 * 自定义模板引擎——模板类
 */
public class CustomTemplate extends AbstractTemplate implements Serializable {
    private StringBuilder stringBuilder;
    private String prefix;
    private String suffix;

    public CustomTemplate(StringBuilder stringBuilder, String prefix, String suffix) {
        this.stringBuilder = stringBuilder;
        this.prefix = prefix;
        this.suffix = suffix;
    }

    @Override
    public void render(Map<?, ?> bindingMap, Writer writer) {
        for (Object key : bindingMap.keySet()) {
            String keyStr = StrUtil.concat(false, prefix, String.valueOf(key), suffix);
            String valStr = String.valueOf(bindingMap.get(key));
            int startIndex = stringBuilder.indexOf(keyStr);
            if (startIndex <= 0) continue;
            int endIndex = startIndex + keyStr.length();
            stringBuilder.replace(startIndex, endIndex, valStr);
        }
        try {
            writer.append(stringBuilder.toString());
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Override
    public void render(Map<?, ?> bindingMap, OutputStream out) {
        // TODO
    }
}

编写测试代码

测试json文件

{
  "name": $name$,
  "text": $text$
}

测试类

package com.hx.core;

import cn.hutool.core.lang.Dict;
import cn.hutool.extra.template.Template;
import cn.hutool.extra.template.TemplateConfig;
import cn.hutool.extra.template.TemplateEngine;
import cn.hutool.extra.template.TemplateUtil;
import com.hx.core.jsonTemplate.JsonTemplateEngine;

public class Test1 {
    public static void main(String[] args) {
        //自动根据用户引入的模板引擎库的jar来自动选择使用的引擎
        //TemplateConfig为模板引擎的选项,可选内容有字符编码、模板路径、模板加载方式等,默认通过模板字符串渲染
        TemplateConfig config = new TemplateConfig();
        config.setCustomEngine(JsonTemplateEngine.class);
        TemplateEngine templateEngine = TemplateUtil.createEngine(config);
        Template template = templateEngine.getTemplate("hello $name$");
        //Dict本质上为Map,此处可用Map
        String result = template.render(Dict.create().set("name", "Huathy"));
        System.out.println("result = " + result);

        // 使用方式二
        TemplateConfig templateConfig = new TemplateConfig("", TemplateConfig.ResourceMode.CLASSPATH);
        TemplateEngine templateEngine2 = new JsonTemplateEngine(templateConfig);
        Template template2 = templateEngine2.getTemplate("test.json");
        String res2 = template2.render(Dict.create()
                .set("name", "Huathy")
                .set("text","这种方式的json文件格式化时不会乱码"));
        System.out.println("res2 = " + res2);
    }
}

输出:
在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要将自定义类型转换JSON集合,可以按照以下步骤操作: 1. 创建一个MyBatis TypeHandler实现类,实现TypeHandler接口,或者继承BaseTypeHandler类。例如,可以创建一个名为JsonListTypeHandler的类。 2. 在TypeHandler实现类中重写setNonNullParameter方法和getNullableResult方法。setNonNullParameter方法用于将Java对象转换为数据库字段值,getNullableResult方法用于将数据库字段值转换Java对象。 3. 在setNonNullParameter方法中,可以使用JSON库(如Jackson或GSON)将Java对象转换JSON字符串,然后将JSON字符串设置到PreparedStatement对象中。 4. 在getNullableResult方法中,可以从ResultSet对象中获取数据库字段值,并使用JSON库将JSON字符串转换Java对象。 5. 在MyBatis配置文件(如mybatis-config.xml)中注册这个TypeHandler。可以通过typeHandlers标签将TypeHandler实现类与自定义Java类型关联起来。例如,可以添加以下配置: ```xml <typeHandlers> <typeHandler handler="com.example.JsonListTypeHandler" javaType="com.example.CustomTypeList"/> </typeHandlers> ``` 这里的"com.example.JsonListTypeHandler"是TypeHandler实现类的完整类名,"com.example.CustomTypeList"是自定义Java类型的完整类名。 6. 在映射文件中,使用自定义Java类型和对应的数据库字段。例如: ```xml <resultMap id="customTypeListMap" type="com.example.CustomTypeList"> <id property="id" column="id" /> <result property="name" column="name" /> </resultMap> ``` 通过以上步骤,就可以将自定义类型转换JSON集合了。在查询时,MyBatis将自动应用TypeHandler,将数据库字段值转换Java对象;在插入或更新时,MyBatis将自动应用TypeHandler,将Java对象转换为数据库字段值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Huathy-雨落江南,浮生若梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值