freemarker html 引入script_FreeMarker模板注入

本文介绍了FreeMarker模板引擎的工作原理及其在Web开发中的应用。重点讨论了如何利用FreeMarker进行动态表达式和标签的利用,包括执行命令的方法。文章提到了通过TemplateModel的exec方法和官方提供的标签执行命令,并分析了2.3.17版本中为防止命令执行所添加的限制。同时,作者探讨了如何突破这些限制,如利用get_optional_template变量实现类似PHP文件包含的漏洞利用方式。
摘要由CSDN通过智能技术生成

一、简介

74b16dc5cfd34553394582cbb0f69d79.png

FreeMarker是一款模板引擎,通过Java类库引入,模板文件简称为FTL(后缀可能也为这个)。输出方式为MVC(模型,视图,控制器)模式,适用于Web开发框架生成html页面。所以此类库经常应用于MVC开发模式的Java Web程序。

二、利用与发掘

74b16dc5cfd34553394582cbb0f69d79.png

既然简介为模板引擎,那么就一定有可以动态利用的地方。FreeMarker动态处理变量为${}格式,当然还有标签格式,这个稍后讲解。看到这里,是不是很像el、spel引擎模板的解析风格,不过确实有相似部分,当然也有区别。接下来,通过代码分析利用方式或常见格式:

Configuration configuration = new Configuration();String templateContent = "${1+1}";Template tpl = new Template(null, templateContent, configuration);StringWriter writer = new StringWriter();tpl.process(null, writer);System.out.println(writer
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值