首页 > Java > java教程 > 正文

Freemarker模板引擎:解决NonHashException字符串比较问题

碧海醫心
发布: 2025-06-30 18:42:01
原创
351人浏览过

freemarker模板引擎:解决nonhashexception字符串比较问题

本文旨在解决在使用Apache Freemarker模板引擎时,遇到的freemarker.core.NonHashException: Expected a hash, but this has evaluated to a string 错误,并提供正确的字符串比较方法。该错误通常发生在尝试访问对象属性时,Freemarker将其误判为字符串。通过理解Freemarker的字符串处理方式,可以有效避免此类问题。

问题分析

在使用Freemarker模板引擎进行开发时,当尝试访问一个对象的属性,并进行字符串比较时,可能会遇到NonHashException。例如,在Spring MVC项目中,从Controller传递一个Java对象到Freemarker模板,并尝试访问该对象的String类型的属性时,可能会出现如下错误:

freemarker.core.NonHashException: For "." left-hand operand: Expected a hash, but this has evaluated to a string (wrapper: f.t.SimpleScalar):
==> previousSearch.status  [in template "ticket/search.ftlh" at line 22, column 66]
登录后复制

这个错误表明Freemarker期望.左边的操作数是一个Hash(类似于Java中的Map),但实际却是一个字符串。

原因探究

出现这种问题的原因在于Freemarker对字符串的处理方式与Java有所不同。在Java中,我们通常使用.equals()方法来比较字符串的内容。但在Freemarker中,推荐使用==运算符来进行字符串比较。

解决方案

将Freemarker模板中的.equals()方法替换为==运算符即可解决此问题。

例如,将以下代码:

<option value="ALL" <#if previousSearch.status.equals("ALL")>selected</#if>>Alle anzeigen</option>
登录后复制

修改为:

<option value="ALL" <#if previousSearch.status == "ALL">selected</#if>>Alle anzeigen</option>
登录后复制

通过这种方式,Freemarker可以正确地比较字符串,从而避免NonHashException。

示例代码

假设有一个Java类 TicketSearchForm:

import lombok.Data;

@Data
public class TicketSearchForm {
    private String status = "ALL";
}
登录后复制

在Spring MVC Controller中,将该对象传递到Freemarker模板:

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class TicketController {

    @GetMapping("/search")
    public String search(Model model) {
        TicketSearchForm previousSearch = new TicketSearchForm();
        previousSearch.setStatus("OPEN"); // 设置状态为OPEN
        model.addAttribute("previousSearch", previousSearch);
        return "ticket/search"; // 假设模板文件为 ticket/search.ftlh
    }
}
登录后复制

对应的Freemarker模板 ticket/search.ftlh:

登录后复制

在这个例子中,使用previousSearch.status == "ALL" 来比较字符串,可以正确地根据previousSearch对象的status属性值来设置

注意事项

  • 始终使用==运算符在Freemarker模板中比较字符串。
  • 确保传递到Freemarker模板的对象属性类型与模板中使用的类型一致。
  • 在复杂的场景下,可以使用Freemarker提供的内置函数,如?string 将其他类型转换为字符串后再进行比较。

总结

解决Freemarker模板引擎中NonHashException的关键在于理解Freemarker对字符串的处理方式。通过使用==运算符代替.equals()方法进行字符串比较,可以避免该错误的发生,并确保模板的正确执行。 记住,Freemarker的语法与Java有所不同,需要仔细区分。

以上就是Freemarker模板引擎:解决NonHashException字符串比较问题的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号