freemarker.template.TemplateException: Expected string. column.nullable evaluated instead to freemar

错误信息:

五月 11, 2017 5:03:32 下午 freemarker.log.JDK14LoggerFactory$JDK14Logger error
严重: Template processing error: "Expected string. column.nullable evaluated instead to freemarker.template.TemplateBooleanModel$1 on line 61, column 86 in baseTemplate/java_src/${basepackage_dir}/interfaceDoc/${className}Doc.html."

Expected string. column.nullable evaluated instead to freemarker.template.TemplateBooleanModel$1 on line 61, column 86 in baseTemplate/java_src/${basepackage_dir}/interfaceDoc/${className}Doc.html.
The problematic instruction:
----------
==> ${column.nullable?right_pad(5," ")} [on line 61, column 84 in baseTemplate/java_src/${basepackage_dir}/interfaceDoc/${className}Doc.html]
----------

Java backtrace for programmers:
----------
freemarker.template.TemplateException: Expected string. column.nullable evaluated instead to freemarker.template.TemplateBooleanModel$1 on line 61, column 86 in baseTemplate/java_src/${basepackage_dir}/interfaceDoc/${className}Doc.html.
	at freemarker.core.TemplateObject.invalidTypeException(TemplateObject.java:136)
	at freemarker.core.BuiltIn$right_padBI._getAsTemplateModel(BuiltIn.java:1332)
	at freemarker.core.Expression.getAsTemplateModel(Expression.java:89)
	at freemarker.core.MethodCall._getAsTemplateModel(MethodCall.java:86)
	at freemarker.core.Expression.getAsTemplateModel(Expression.java:89)
	at freemarker.core.Expression.getStringValue(Expression.java:93)
	at freemarker.core.DollarVariable.accept(DollarVariable.java:76)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.MixedContent.accept(MixedContent.java:92)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.IteratorBlock$Context.runLoop(IteratorBlock.java:179)
	at freemarker.core.Environment.visit(Environment.java:428)
	at freemarker.core.IteratorBlock.accept(IteratorBlock.java:102)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.MixedContent.accept(MixedContent.java:92)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.Environment.process(Environment.java:199)
	at freemarker.template.Template.process(Template.java:259)
	at cn.org.rapid_framework.generator.Generator.saveNewOutputFileContent(Generator.java:233)
	at cn.org.rapid_framework.generator.Generator.generateNewFileOrInsertIntoFile(Generator.java:167)
	at cn.org.rapid_framework.generator.Generator.generateByModelProvider(Generator.java:126)
	at cn.org.rapid_framework.generator.Generator.generateByModelProvider(Generator.java:83)
	at cn.org.rapid_framework.generator.GeneratorFacade.generateByTable(GeneratorFacade.java:117)
	at cn.org.rapid_framework.generator.GeneratorMain.main(GeneratorMain.java:76)

Exception in thread "main" java.lang.RuntimeException: generate 'Database Table:equipment to ClassName:Equipment' oucur error,template is:baseTemplate/java_src/${basepackage_dir}/interfaceDoc/${className}Doc.html
	at cn.org.rapid_framework.generator.Generator.generateByModelProvider(Generator.java:128)
	at cn.org.rapid_framework.generator.Generator.generateByModelProvider(Generator.java:83)
	at cn.org.rapid_framework.generator.GeneratorFacade.generateByTable(GeneratorFacade.java:117)
	at cn.org.rapid_framework.generator.GeneratorMain.main(GeneratorMain.java:76)
Caused by: freemarker.template.TemplateException: Expected string. column.nullable evaluated instead to freemarker.template.TemplateBooleanModel$1 on line 61, column 86 in baseTemplate/java_src/${basepackage_dir}/interfaceDoc/${className}Doc.html.
	at freemarker.core.TemplateObject.invalidTypeException(TemplateObject.java:136)
	at freemarker.core.BuiltIn$right_padBI._getAsTemplateModel(BuiltIn.java:1332)
	at freemarker.core.Expression.getAsTemplateModel(Expression.java:89)
	at freemarker.core.MethodCall._getAsTemplateModel(MethodCall.java:86)
	at freemarker.core.Expression.getAsTemplateModel(Expression.java:89)
	at freemarker.core.Expression.getStringValue(Expression.java:93)
	at freemarker.core.DollarVariable.accept(DollarVariable.java:76)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.MixedContent.accept(MixedContent.java:92)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.IteratorBlock$Context.runLoop(IteratorBlock.java:179)
	at freemarker.core.Environment.visit(Environment.java:428)
	at freemarker.core.IteratorBlock.accept(IteratorBlock.java:102)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.MixedContent.accept(MixedContent.java:92)
	at freemarker.core.Environment.visit(Environment.java:221)
	at freemarker.core.Environment.process(Environment.java:199)
	at freemarker.template.Template.process(Template.java:259)
	at cn.org.rapid_framework.generator.Generator.saveNewOutputFileContent(Generator.java:233)
	at cn.org.rapid_framework.generator.Generator.generateNewFileOrInsertIntoFile(Generator.java:167)
	at cn.org.rapid_framework.generator.Generator.generateByModelProvider(Generator.java:126)
	... 3 more

有文章 提到使用

  ${ isExit ?string("true","false")}


但我亲测根本不能用,

后来发现是我的freeMarker 的版本问题;


由于 column.nullable 是 Boolean 类型, freemarker 2.3.19 默认不支持 Boolean 类型

请升级到最新版本:2.3.26


<input name="isExit" type="hidden" value="${isExit?string('true','false')}" />  


freemarker用于取布尔类型的值:

实际例子:


重点:${basic.isDelete?string ("true","false")}"

说明:用于取布尔类型的值,string 用于将布尔值转换为字符串输出,true转为“true”,false转换为“false”,basic源于<#list business.result as basic></#list>,idDeletejavaBean里面的一个属性。


freemarker 低版本不支持布尔类型,而且 ${column.isNullable} ${column.nullable} 都会查找相同的方法;


### Java中ClassNotFoundException异常:freemarker.template.Configuration的解决方案 `java.lang.ClassNotFoundException: freemarker.template.Configuration` 异常表明程序在运行时无法找到 `freemarker.template.Configuration` 类。此问题通常与依赖项未正确添加到项目中有关。以下是解决该问题的具体方法: #### 1. 检查依赖是否已添加 确保项目的构建工具(如 Maven 或 Gradle)中已包含 FreeMarker 的依赖项。以下是 Maven 和 Gradle 中的依赖配置示例。 **Maven 配置:** ```xml <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.31</version> <!-- 确保使用最新稳定版本 --> </dependency> ``` **Gradle 配置:** ```gradle implementation 'org.freemarker:freemarker:2.3.31' // 确保使用最新稳定版本 ``` 通过添加上述依赖,可以确保 `freemarker.template.Configuration` 类被正确引入到项目中[^3]。 #### 2. 验证依赖是否生效 在某些情况下,即使添加了依赖,也可能由于缓存或网络问题导致依赖未正确下载。可以尝试以下操作: - 清理并重新构建项目: - 对于 Maven 项目,运行命令 `mvn clean install`。 - 对于 Gradle 项目,运行命令 `gradle clean build`。 - 检查本地仓库中是否存在 FreeMarker 的 JAR 文件。路径通常为 `~/.m2/repository/org/freemarker/freemarker/`(对于 Maven)或类似路径(对于 Gradle)[^4]。 #### 3. 检查类加载器配置 如果依赖已正确添加但问题仍然存在,可能是类加载器的配置问题。确保 `freemarker.template.Configuration` 被正确的类加载器加载。可以通过以下代码验证类是否存在: ```java try { Class.forName("freemarker.template.Configuration"); System.out.println("Class found!"); } catch (ClassNotFoundException e) { System.out.println("Class not found!"); e.printStackTrace(); } ``` 如果输出为 `Class not found!`,则需要进一步检查项目的依赖配置和运行环境[^1]。 #### 4. 使用兼容版本 FreeMarker 的不同版本可能与其他库存在兼容性问题。建议根据项目需求选择合适的 FreeMarker 版本。例如,MyBatis-Plus 推荐使用 FreeMarker 2.3.28 或更高版本[^2]。 --- ### 示例代码:验证 FreeMarker 是否正常工作 以下是一个简单的 FreeMarker 测试代码,用于验证依赖是否正确加载: ```java import freemarker.template.Configuration; import freemarker.template.Template; public class FreemarkerTest { public static void main(String[] args) { try { Configuration cfg = new Configuration(Configuration.VERSION_2_3_31); System.out.println("FreeMarker Configuration initialized successfully."); } catch (Exception e) { System.err.println("Failed to initialize FreeMarker Configuration."); e.printStackTrace(); } } } ``` 如果程序能够成功初始化 `Configuration` 对象,则说明依赖已正确加载。 --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值