描述:本内容主要是讲2个tomcat之间同时共享一个静态话页面,统一入口是springMVC的一个controller,静态化的更新只需要传false、true。把完成的web项目放入a、b服务器Tomca,可同时访问同一个页面。

Tomcat虚拟资源映射

一、tomcat中共享虚拟目录

、在tomcat中server.xml文件中,可配置多个tomcat映射到同一个内存服务磁盘,并共享资源
<Context docBase="C:\springMVCFreeMarker" path="/springMVCFreeMarker" privileged="true"/>

docBase:内存服务磁盘 path文件保存路径

、配置springMVC.xml文件,静态资源,请求则不会进行拦截。
<mvc:resources location="/springMVCFreeMarker/" mapping="/springMVCFreeMarker/**" />

二 、测试

http://localhost:1111/ path名/后面任何文件…

例:http://localhost:1111/springMVCFreeMarker/1.jpg

三、页面静态化的控制需要

场景:
1、不通过静态化,每次都从*.ftl模版中加载,并得到视图(不需要文件加载)。
2、每一的请求都是一个新的html文件。
3、静态化一次,下次静态化手动控制。

Freemarker的半自动静态化

一、视图解析器

 <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
 <property name="suffix" value=".ftl" />
 <property name="contentType" value="text/html; charset=UTF-8"></property>
 <property name="viewClass"alue="com. freemarker. Controller.FreeMarkerViewUtil"/>
 <property name="exposeRequestAttributes" value="true" />
 property name="exposeSessionAttributes" value="true" />
 <property name="exposeSpringMacroHelpers" value="true" />
 </bean>
 1、<!-- 将请求和会话属性作为变量暴露给FreeMarker模板使用。要做到这一点,可以设置exposeRequestAttributes或者exposeSessionAttributes为true -->
 2、<!-- 使用这些宏,必须设置FreeMarkerViewResolver的exposeMacroHelpers属性为true -->  

二、视图模版加载配置

<bean id="fmXmlEscape" class="freemarker. template. utility. XmlEscape" />
<bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker. FreeMarkerConfigurer">
<! -- ##模版的存放路径:value="/WEB-INF/view/"-->
    <property name="templateLoaderPath" value="/WEB-INF/view/" />
    <property name="freemarkerVariables">
        <map>
            <entry key="xml_escape" value-ref="fmXmlEscape" />
        </map>
    </property>
    <property name="freemarkerSettings">
        <props>
            <! -- ##模板更新事件,设置为1秒,正式环境设置为3600秒 -->
            <prop key="template_update_delay">1</prop>
            <! -- 编码utf8 -->
            <prop key="default_encoding">UTF-8</prop>
            <! -- ##数字显示格式 -->
            <prop key="number_format">0.##########</prop>
            <! -- ##显示日期格式 -->
            <prop key="datetime_format">yyyy-MM-dd HH:mm: ss</prop>
    <! -- ##如果变量为null,转化为空字符串,比如做比较的时候按照空字符串做比较 -->
            <prop key="classic_compatible">true</prop>
            <prop key="template_exception_handler">ignore</prop>
            </props>
        </property>
    </bean>

Maven配置

     <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
            <version>2.3.20</version>
        </dependency>
        <dependency>
            <groupId>freemarker</groupId>
            <artifactId>freemarker</artifactId>
            <version>2.3.8</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>4.2.4. RELEASE</version>
        </dependency>

三、视图工具FreeMarkerViewUtil

注意导包!!!!
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.util.Locale;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.support.RequestContextUtils;
import org.springframework.web.servlet.view.freemarker.FreeMarkerView;
import freemarker.template.SimpleHash;
import freemarker.template.Template;
import freemarker.template.TemplateException;
public class FreeMarkerViewUtil extends FreeMarkerView {
    private final static String PATH = "C:\\springMVCFreeMarker";

    @Override
    protected void doRender(Map<String, Object> model, HttpServletRequest request, HttpServletResponse response)
            throws Exception {
        exposeModelAsRequestAttributes(model, request);
        SimpleHash fmModel = buildTemplateModel(model, request, response);
        if (logger.isDebugEnabled()) {
            logger.debug("Rendering FreeMarker 模版 [" + getUrl() + "] in FreeMarkerView '" + getBeanName() + "'");
        }
        Locale locale = RequestContextUtils.getLocale(request);
        if (Boolean.TRUE.equals(model.get("CREATE_HTML")) && model.get("RENEW") != null) {
            createHTML(getTemplate(locale), fmModel, request, response,model.get("RENEW").toString());
            System.err.println("1、已经静态化了");
        } else if (Boolean.FALSE.equals(model.get("CREATE_HTML"))) {
            processTemplate(getTemplate(locale), fmModel, response);
            System.err.println("2、不需要静态化");
        } else {
            createHTML(getTemplate(locale), fmModel, request, response,"");
            System.err.println(" 3、请求每次更新");
        }
    }

    public void createHTML(Template template, SimpleHash model, HttpServletRequest request,
            HttpServletResponse response,String o) throws IOException, TemplateException, ServletException {
        String requestHTML = this.getRequestHTML(request);
        String htmlPath = PATH + requestHTML;
        final  String STATICPATH = "http://"+request.getServerName()+":"+request.getServerPort()+"/springMVCFreeMarker";
        Boolean on = UpdateFile(htmlPath,o);
        if (on) {
            File htmlFile = new File(htmlPath);
            if (!htmlFile.getParentFile().exists()) {
                htmlFile.getParentFile().mkdirs();
            }
            if (!htmlFile.exists()) {
                htmlFile.createNewFile();
            }
            Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(htmlFile), "UTF-8"));
            template.process(model, out);
            out.flush();
            out.close();
            response.sendRedirect(STATICPATH + requestHTML);
            System.err.println("新的生成!");
        } else {
            // request.getRequestDispatcher("../FreeMarker/"+requestHTML).forward(request,response);
            response.sendRedirect(STATICPATH + requestHTML);
            System.err.println("不需要静态化!");
        }

    }

    /**
     * 计算要生成的静态文件相对路径 因为大家在调试的时候一般在Tomcat的webapps下面新建站点目录的,
     * 但在实际应用时直接布署到ROOT目录里面,这里要保证路径的一致性。
     *
     * @param request
     *            HttpServletRequest
     * @return /目录/*.htm
     */
    private String getRequestHTML(HttpServletRequest request) {
        String contextPath = request.getContextPath();
        String requestURI = request.getRequestURI();
        requestURI = requestURI.replaceFirst(contextPath, "");
        requestURI = requestURI.substring(0, requestURI.indexOf(".")) + ".html";
        return requestURI;
    }

    /**
     * 传入xxx重新生成:
     *
     * @param filePath
     * @param updateTime
     * @return
     */
    private boolean UpdateFile(String filePath,String onRENEW) {
        File dest = new File(filePath);
        //dest.exists()&& dest.lastModified() > (System.currentTimeMillis() - updateTime)
        if ((filePath.endsWith(".html") &&onRENEW.equals("RENEW"))||(filePath.endsWith(".html") &&onRENEW.equals(""))) {
            return true;
        } else if (!dest.exists()) {
            return true;
        }
        return false;
    }

}

三、Controller层使用场景

              

编写ftl模版

    说明:Html视图是通过加载ftl模版后得到的:java对象数据+ftl模型=视图view,模版ftl文件一般存放的路径:WebContent/WEB-INF/view/*.ftl

    

二、freemarker.controller半自动静态化+Tomcat虚拟资源映射的更多相关文章

  1. Freemarker 之 Java静态化 实例一

    Freemarker是一种强大的web端模板技术,在当前Web开发中,SEO和客户端浏览速度尤为重要,其中将网页静态化是一个很好的解决方案.下面介绍Java中web开发结合Freemarker来实现静 ...

  2. 关于大型网站技术演进的思考(二十一)--网站静态化处理—web前端优化—下【终篇】(13)

    本篇继续web前端优化的讨论,开始我先讲个我所知道的一个故事,有家大型的企业顺应时代发展的潮流开始投身于互联网行业了,它们为此专门设立了一个事业部,不过该企业把这个事业部里的人事成本,系统运维成本特别 ...

  3. Tomcat 虚拟目录映射

    最近老是被一个旧Ant工程所困扰,代码版本都改好了测试也通过了,就是打不了war包,一看build.xml 我的天 各种逆天啊....头大.于是乎想起了最基础的tomcat虚拟目录虽是一个很基础的点, ...

  4. 关于大型网站技术演进的思考(二十)--网站静态化处理—web前端优化—中(12)

    Web前端很多优化原则都是从如何提升网络通讯效率的角度提出的,但是这些原则使用的时候还是有很多陷阱在里面,如果我们不能深入理解这些优化原则背后所隐藏的技术原理,很有可能掉进这些陷阱里,最终没有达到最佳 ...

  5. tomcat虚拟目录映射网络共享目录

    <Host name="localhost" debug="0" appBase="webapps" unpackWARs=" ...

  6. 页面静态化技术Freemarker技术的介绍及使用实例.

    一.FreeMarker简介 1.动态网页和静态网页差异 在进入主题之前我先介绍一下什么是动态网页,动态网页是指跟静态网页相对应的一种网页编程技术.静态网页,随着HTML代码的生成,页面的内容和显示效 ...

  7. 利用freemarker 静态化网页

    1.介绍-FreeMarker是什么 模板引擎:一种基于模板的.用来生成输出文本的通用工具 基于Java的开发包和类库 2.介绍-FreeMarker能做什么 MVC框架中的View层组件 Html页 ...

  8. 利用FreeMarker静态化网页

    1.介绍-FreeMarker是什么 模板引擎:一种基于模板的.用来生成输出文本的通用工具 基于Java的开发包和类库 2.介绍-FreeMarker能做什么 MVC框架中的View层组件 Html页 ...

  9. Spring MVC 学习总结(七)——FreeMarker模板引擎与动态页面静态化

    模板引擎可以让程序实现界面与数据分离,业务代码与逻辑代码的分离,这就提升了开发效率,良好的设计也使得代码复用变得更加容易.一般的模板引擎都包含一个模板解析器和一套标记语言,好的模板引擎有简洁的语法规则 ...

随机推荐

  1. 浅谈Android样式开发之selector

    引言 上一篇Android UI中文章我们详细介绍了Android中shape标签的使用.通过shape标签我们可以定义矩形.椭圆.环形.直线等效果.不过shape只能定义单一的形状,在实际开发中,我 ...

  2. hortonworks2.5.3 install step log

    1.创建本地YUM源,下载TAR.GZ HDP,HDP-UTILS,AMBARI介质安装HTTPD,在/VAR/WWW/HTML/下创建三个相应的目录,把以上解压的三个目录链接过来在三个目录中执行命令 ...

  3. DataTable 批量插入SqlServer数据库 使用:SqlBulkCopy

    简单使用: private void UpdateTitle(DataTable dt) { ) { using (SqlBulkCopy sbc = new SqlBulkCopy(SqlHelpe ...

  4. CART(分类回归树)

    1.简单介绍 线性回归方法可以有效的拟合所有样本点(局部加权线性回归除外).当数据拥有众多特征并且特征之间关系十分复杂时,构建全局模型的想法一个是困难一个是笨拙.此外,实际中很多问题为非线性的,例如常 ...

  5. mysql union和union all的区别

    union 对两个结果集进行并集操作,重复数据只显示一次 Union All,对两个结果集进行并集操作,重复数据全部显示 工具/原料 mysql 数据库 方法/步骤   student表数据   使用 ...

  6. 3分钟,9个Q&amp;A让你快速知道Docker到底是什么

    不论是Google.Amazon.Microsoft.VMware都纷纷拥戴,加入Docker和Container所掀起的新时代云端虚拟化行列,这两项技术成为了IT界的新趋势.Docker和Conta ...

  7. Nginx图片剪裁模块探究 http_image_filter_module

    官方地址:http://nginx.org/en/docs/http/ngx_http_image_filter_module.html 煮酒品茶:前半部安装和官方说明,后半部分实践 #yum ins ...

  8. LCS(滚动数组) POJ 1159 Palindrome

    题目传送门 题意:一个字符串要变成回文串至少要插入多少个字符 分析:LCS,长度 - 原串和反串的最大相同长度就是要插入的个数.解释一下,当和反串相同时,在原串中已经是回文的部分了,那么减去LCS长度 ...

  9. Squares 分类: POJ 2015-08-04 11:46 3人阅读 评论(0) 收藏

    Squares Time Limit: 3500MS Memory Limit: 65536K Total Submissions: 17462 Accepted: 6634 Description ...

  10. [git]Git与Repo入门

    转自:http://www.cnblogs.com/angeldevil/archive/2013/11/26/3238470.html 注:非常推荐的一篇关于git的博文 目录: 版本控制 一.原始 ...