转自:http://angelbill3.iteye.com/blog/1980904

在springMVC的项目中,加入freemarker

1、首先导入springMVC-webmvc所需的JAR包。 
(若用maven的话,如下)

  1. <dependency>
  2. <groupId>org.springfremework</groupId>
  3. <artifactId>spring-webmvc<artifactId>
  4. <version>3.2.3.RELEASE</version>
  5. </dependency>

2、配置web.xml(启动mvc框架)

  1. <servlet>
  2. <servlet-name>spring</servlet-name>
  3. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  4. <load-on-startup>1</load-on-startup>
  5. </servlet>
  6. <servlet-mapping>
  7. <servlet-name>spring</servlet-name>
  8. <url-pattern>*.htm</url-pattern>
  9. </servlet-mapping>

相应的xml配置命令规则为:【servlet名字】-servlet.xml,(如本文为:spring-servlet.xml),默认目录和web.xml放一起,即WEB-INF目录下。

3、配置spring-servlet.xml(****重要****) 
在spring-servlet文件中加入:(annotation以及包扫描范围已略。) 
关于freemarker模版的配置,可以直接在xml里配,也可以用properties文件配。

  1. <!-- 设置freeMarker的配置文件路径 -->
  2. <bean id="freemarkerConfiguration" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
  3. <property name="location" value="classpath:conf/freemarker.properties"/>
  4. </bean>
  5. <!-- 配置freeMarker的模板路径 -->
  6. <bean class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
  7. <property name="freemarkerSettings" ref="freemarkerConfiguration"/>
  8. <property name="templateLoaderPath">
  9. <value>/WEB-INF/ftl/</value>
  10. </property>
  11. </bean>
  12. <!-- 配置freeMarker视图解析器 -->
  13. <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
  14. <property name="viewClass" value="org.springframework.web.servlet.view.freemarker.FreeMarkerView"/>
  15. <property name="contentType" value="text/html; charset=utf-8"/>
  16. <property name="cache" value="true"/>
  17. </bean>

4、新建文件:freemarker.properties,放conf目录下

  1. #设置标签类型:square_bracket:[]     auto_detect:[]<>
  2. tag_syntax=auto_detect
  3. #模版缓存时间,单位:秒
  4. template_update_delay=0
  5. default_encoding=UTF-8
  6. output_encoding=UTF-8
  7. locale=zh_CN
  8. #设置数字格式 ,防止出现 000.00
  9. number_format=\#
  10. #变量为空时,不会报错
  11. classic_compatible=true
  12. #这个表示每个freemarker的视图页面都会自动引入这个ftl文件。里面定议的就是一些宏,如text文本框,各种form元素
  13. #auto_import="/WEB-INF/templates/index.ftl" as do

这个模版属性是比较基本的定义,其中比较重要的是最后一条:auto_import="/WEB-INF/templates/index.ftl" as do,这个表示每个freemarker的视图页面都会自动引入这个ftl文件。里面定议的就是一些宏,如text文本框,各种form元素(本文没作深入研究。)

5、后台新建测试Control类:FreemarkerController

  1. import org.springframework.stereotype.Controller;
  2. import org.springframework.ui.ModelMap;
  3. import org.springframework.web.bind.annotation.RequestMapping;
  4. @Controller
  5. public class FreemarkerController {
  6. @RequestMapping("/hi")
  7. public String sayHello(ModelMap map){
  8. System.out.println("say hi ……");
  9. map.put("name", "kimi");
  10. return "/hi.ftl";
  11. }
  12. }
  13. 6、前台新建测试页:hi.ftl(放WEB-INF/ftl目录下)
  14. <pre class="java" name="code"><html>
  15. <body>
  16. <h1>holle world ${name}</h1><br/>
  17. 1 + 1 = 3? ${(1 != 1)?string("yes", "no")}
  18. </body>
  19. </html>
  20. </pre>
  21. <br>

7、启动项目。 
发现报错:Caused by: java.lang.NoClassDefFoundError: org/springframework/ui/freemarker/FreeMarkerConfigurationFactory

少了jar包,再导入spring-context-support-3.2.3.RELEASE包即可。 
maven:

  1. <dependency>
  2. <groupId>org.springframework</groupId>
  3. <artifactId>spring-context-support</artifactId>
  4. <version>3.2.3.RELEASE</version>
  5. </dependency>

再次启动,没有错,访问项目后,网页内容如下: 

------------------------------------------ 
参考资料: 
http://www.360doc.com/content/12/0809/13/4280915_229198282.shtml

springMVC+freemarker整合的更多相关文章

  1. sonne_game网站开发03 spring-mvc+freemarker整合

    今天的任务就是在spring+mybatis+springmvc的基础上,将freemarker整合进来. freemarker是什么? freemarker是一种模板引擎.它的目的是基于模板和数据, ...

  2. spring-mvc+freemarker整合(sonne_game网站开发03)

    今天的任务就是在spring+mybatis+springmvc的基础上,将freemarker整合进来. freemarker是什么? freemarker是一种模板引擎.它的目的是基于模板和数据, ...

  3. SpringMVC+spring-security+sitemesh+hibernate+freemarker整合-转

    http://www.oschina.net/code/snippet_170632_46774 代码分享 当前位置: 代码分享 » Java  » Web编程 搜 索   SpringMVC+spr ...

  4. SpringMVC和Freemarker整合,带自定义标签的使用方法

    SpringMVC和Freemarker整合,带自定义标签的使用方法. [参考来源:http://www.360doc.com/content/14/1225/14/1007797_435663342 ...

  5. springMVC与freemarker整合

    准备好的环境:Maven工程整合好了ssm,即spring+springMVC+mybatis.接下来准备将springMVC与freemarker整合,以html文件为模板. 一,加入freemar ...

  6. freemarker学习 (servlet + freemarker -> Struts2+freemarker -> springMVC+freemarker)

    什么是freemarker? freemarker类似于jsp,但不是jsp!怎么说呢?freemarker文件后缀是.ftl,它不像jsp本质是servlet,它将构建模板.解析模板.使用模板分离开 ...

  7. 【FreeMarker】Spring MVC与FreeMarker整合(二)

    前一篇介绍了FreeMarker的基本使用,本例介绍Spring MVC与FreeMarker整合 不熟悉项目搭建,可参考 [FreeMarker]FreeMarker快速入门(一) 整合 1.新建S ...

  8. spring源码分析之freemarker整合

    FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具. 它不是面向最终用户的,而是一个Java类库,是一款程 ...

  9. Spring+springmvc+Mybatis整合案例 annotation版(myeclipse)详细版

    Spring+springmvc+Mybatis整合案例 Version:annotation版 文档结构图: 从底层开始做起: 01.配置web.xml文件 <?xml version=&qu ...

随机推荐

  1. Django 模型层 ORM 操作

    运行环境 1. Django:2.1.3 version 2. PyMysql: 0.9.3 version 3. pip :19.0.3 version 4. python : 3.7 versio ...

  2. ASN.1

    ASN.1抽象语法标记(Abstract Syntax Notation One https://baike.baidu.com/item/ASN.1/498523?fr=aladdin

  3. Rxjava Retrofix2 okhttp3网络框架自解(转)

    直接代码 类一 public class Okhttp3Utils { private static OkHttpClient mOkHttpClient; public static OkHttpC ...

  4. 10.ThreadLocal

    /** * - void set(Object value)设置当前线程的线程局部变量的值. * - public Object get()该方法返回当前线程所对应的线程局部变量. * - publi ...

  5. react app相关知识

    1.快速新建名为hello-world项目的应用命令 npx create-react-app hello-world 2.使用serve来mock数据 ①先安装serve        npm i ...

  6. POJ 3159 Candies(spfa、差分约束)

    Description During the kindergarten days, flymouse was the monitor of his class. Occasionally the he ...

  7. http协议和file协议的区别

    1.在本地直接使用浏览器打开  html文件 和 通过本地服务器打开  html文件  有什么区别呢.  https://segmentfault.com/q/1010000006554881/a-1 ...

  8. 分布式系统理论基础6:Raft、Zab

    本文转自:https://www.cnblogs.com/bangerlee/p/5991417.html 本文转自 https://www.cnblogs.com/bangerlee/p/52684 ...

  9. python之绘制函数pyplot初探

    我们想将我们手里的数据通过图形的方式展示出来,这样我们更直观的,更可以发现数据带给我们的信息.今天给大家介绍要给python中pyplot绘制函数.一般我们想将手里的数据绘制成图形,分为四大步:1.准 ...

  10. javascript全量匹配屏蔽词

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...