JAVA集成Freemarker生成靜態(tài)html過程解析
Springboot
1.引入Freemarker jar包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId></dependency>
2.配置application.properties
### freemarkerspring.freemarker.templateLoaderPath=classpath:/templates/spring.freemarker.suffix=.ftlspring.freemarker.charset=UTF-8spring.freemarker.request-context-attribute=requestspring.freemarker.settings.number_format=0.##########
3.創(chuàng)建ftl文件
在resource文件下新增文件夾templates,在templates文件夾下存放ftl文件,例如:
<!DOCTYPE html><html><head> <meta charset='utf-8'/> <title>FreeMarker</title></head><body><h1>Simple project</h1><h1>${key}</h1></body></html>
4.新建controller調(diào)用方法
@SuppressWarnings('unchecked') @RequestMapping(value='/test',method=RequestMethod.GET) public String test(Model model,HttpServletRequest request) { model.addAttribute('key','test project'); return 'test'; }
5.生成html靜態(tài)文件
使用工具類:
/** * @param modeName 模板名稱 * @param targetFileName 生成后的HTML名稱 * @param params 傳入模板的參數(shù) * @Author: zy * @Date: 2020-6-4 09:39:47 * @Description:生成靜態(tài)頁面 */ public void createHtmlByMode(String modeName, String targetFileName, Map<String, Object> params) { Writer out = null; // 找到服務(wù)器緩存目錄,可以自己指定目錄 String folder = PropertisUtil.getApplicationProperties('healthReport.logs.urls') + targetFileName; // 通過匹配路徑格式拼接完整生成路徑 String outFile = folder; try { File file = new File(outFile); // 生成空HTML文件 if (!file.exists()) {file.createNewFile(); } // 創(chuàng)建模版對象 Template template = cfg.getTemplate(modeName); // 設(shè)置輸出流 out = new OutputStreamWriter(new FileOutputStream(file), 'UTF-8');// 設(shè)置編碼 UTF-8 // 模版數(shù)據(jù)插入?yún)?shù),通過輸出流插入到HTML中 template.process(params, out); } catch (Exception e) { e.printStackTrace(); } finally { if (null != out) {try { out.flush(); out.close();} catch (IOException e) { e.printStackTrace();} } } }
修改controller中的方法:
@SuppressWarnings('unchecked') @RequestMapping(value='/test',method=RequestMethod.GET) public String test(Model model,HttpServletRequest request) { model.addAttribute('key','test project'); //生成靜態(tài)文件 Map param=new HashMap(); param.put('key', '我是被生成的靜態(tài)文件'); createHtmlByMode('test.ftl','test.html',param); return 'test'; }
實現(xiàn)效果(我這里默認(rèn)保存到d:/testlogs):
Springmvc(和springboot大致相同,此處只留下配置)
1.引入Freemarker jar包
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>3.2.4.RELEASE</version> </dependency> <!-- https://mvnrepository.com/artifact/org.freemarker/freemarker --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.25-incubating</version> </dependency>
2.springmvc配置
<!-- freemarker --> <bean class='org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer'> <property name='templateLoaderPath' value='/freemarker/ftl/'></property> <property name='defaultEncoding' value='utf-8' /> <property name='freemarkerSettings'> <props><prop key='template_update_delay'>1</prop><prop key='locale'>zh_CN</prop><prop key='datetime_format'>yyyy-MM-dd</prop><!-- 時間格式化 --><prop key='date_format'>yyyy-MM-dd</prop><prop key='number_format'>#.##</prop> </props> </property> </bean> <bean class='org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver'> <property name='cache' value='true' /> <property name='prefix' value='' /><!-- 上面已經(jīng)配了,這里就不用配啦 --> <property name='suffix' value='.ftl' /> <property name='contentType' value='text/html;charset=UTF-8' /> <property name='allowSessionOverride' value='true' /> <property name='allowRequestOverride' value='true' /> <property name='exposeSpringMacroHelpers' value='true' /> <property name='exposeRequestAttributes' value='true' /> <property name='exposeSessionAttributes' value='true' /> <property name='requestContextAttribute' value='request' /> </bean>
3.調(diào)用方式
/**返回模板信息*/ @SuppressWarnings('unchecked') @RequestMapping(value='/test',method={RequestMethod.GET}) public ModelAndView test(HttpServletRequest request) { ModelAndView mv = new ModelAndView(); //設(shè)置參數(shù) mv.addObject('key', '測試freemarker'); //配置模板 mv.setViewName('test'); return mv; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 測試模式 - XSL教程 - 52. python b站視頻下載的五種版本3. 如何通過vscode運行調(diào)試javascript代碼4. 解決Java中的java.io.IOException: Broken pipe問題5. Python結(jié)合百度語音識別實現(xiàn)實時翻譯軟件的實現(xiàn)6. JAVA抽象類及接口使用方法解析7. python如何寫個俄羅斯方塊8. 《CSS3實戰(zhàn)》筆記--漸變設(shè)計(一)9. 教你JS更簡單的獲取表單中數(shù)據(jù)(formdata)10. vue實現(xiàn)簡易圖片左右旋轉(zhuǎn),上一張,下一張組件案例
