屏蔽freemarker打印堆栈信息和模板调试时打印堆栈信息到页面

今天看着我们公司之前网站所使用的freemarker模板的时候难免会存在很多语法错误,比如转时间,对象为空然后调用对象的属性,在我们控制台就会打印一些堆栈错误,如果网站正式运行了,那么我们的日志里保存的日志大部分都是freemarker堆栈错误,这个在不需要调试页面的时候是很占资源的,后来我就想我必须要把这个堆栈信息给屏蔽了(我有强迫症)。

在百度搜索了一圈基本上搜索到的都是有关freemarker怎么使用自定义模板异常相关内容(差不多都是TemplateExceptionHandler的使用方式相关的东西),没办法网上找不到,就只有直接找了

查找源码发现org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer配置中的freemarkerSettings增加如下配置

<!-- 关闭freemarker打印堆栈信息 -->
<prop key="log_template_exceptions">false</prop>
加了配置后,后台就不会在打印堆栈信息了

还有就是在开发freemarker模板的时候,前端人员需要使用标签进行获取数据,这个时候我们其实有需要把堆栈信息 (包含业务逻辑层抛出的自定义异常)展示给前端人员看,那么我们需要调整配置如下

<!-- 异常处理freemarker.core.Configurable类中的setSetting方法选项有debug,html_debug,ignore,rethrow,default-->
<prop key="template_exception_handler">html_debug</prop>

debug:该模式会将TemplateException的堆栈信息打印到页面但是不是很友好,没有良好的格式

html_debug:该模式将堆栈信息以html的形式打印到页面上

ignore:该模式不会做任何事,异常该往上层抛就抛

rethrow:该模式会将TemplateException再次抛出

default:该模式和debug模式一样都是同一个异常处理实现

好了总结一下:

template_exception_handler配置只有ignore,rethrow模式不会打印堆栈到前台,其余3个模式都会打印堆栈信息到前台

我把我的配置完整的放在这儿,知道有些兄弟想偷懒

<bean id="freemarkerConfig"
		class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer" scope="singleton" >
<property name="templateLoaderPath" value="/WEB-INF/view" />
<property name="freemarkerSettings">
			<props>
                <prop key="tag_syntax">auto_detect</prop>
                <prop key="template_update_delay">0</prop>
                <prop key="locale">zh_CN</prop>
                <prop key="default_encoding">UTF-8</prop>
                <prop key="number_format">0.##</prop>
                <prop key="datetime_format">yyyy-MM-dd HH:mm:ss</prop>
                <prop key="date_format">yyyy-MM-dd</prop>
                <prop key="classic_compatible">true</prop>
                <prop key="template_exception_handler">ignore</prop>
                <prop key="log_template_exceptions">false</prop>
            </props>
</property>
</bean>




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值