1,简单介绍:
FreeMarker是一个“模板引擎”,生成静态页面,XML等,一个基于模板生成文本输出的第三方工具。可以实现生成HTML网页,设计人员可以用它改变外观,而无需更改或重新编译代码,因为此应用将程序逻辑(Java程序)和网页设计(FreeMarker模板)隔开。运行时可以不依赖Web服务器。也不需要编译。效率比JSP高。文件的扩展名:.ftl 文件的存放位置,一般是在WebRoot目录下。看这张图:
可以看出FreeMarker的主要思想是:模板+数据模型=输出。
2,需要我们了解此知识,使用时具体语法,参考此文:Freemarker使用
综上为页面相关内容的一些知识,主要是页面的跳转,下载跳转等,都是非常基础的知识,这里需要我们多看struts-default.xml文件中知识,通过了解其中的一些配置,以及其对应的类,是非常有意思的。
1,dispatcher:为框架默认的,表示转发到期望的jsp页面。由于框架提供了拦截器,每次执行action需要执行过滤器,如果非得用dispatcher来进行action转发时,需要我们在web.xml进行设置如下:
<filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> <dispatcher>REQUEST</dispatcher> <dispatcher>FORWARD</dispatcher> </filter-mapping>
2,chain:专门提供Action之间进行转发操作的。表示同一次请求链。设置如下:
a,如果两个action在同一个命名空间下进行转发:直接指定另一个action的名称即可。
<package name="example" namespace="/user" extends="struts-default"> <action name="login" class="com.ljh.struts2.action.LoginAction" method="login"> <result name="success" type="chain">test</result> <result name="login">/login.jsp</result> </action> <action name="test" class="com.ljh.struts2.action.TestAction" method="test"> <result name="test" type="dispatcher">/test.jsp</result> </action> </package>
b,如果两个action不在同一个命名空间下进行转发,需要给result指定参数:
<package name="example" namespace="/user" extends="struts-default"> <action name="login" class="com.ljh.struts2.action.LoginAction" method="login"> <result name="success" type="chain"> <param name="namespace">/test</param> <!-- 参数名称需要参考API-(ActionChainResult)文件的说明 --> <param name="actionName">test</param> </result> <result name="login">/login.jsp</result> </action> </package> <package name="test" namespace="/test" extends="struts-default"> <action name="test" class="com.ljh.struts2.action.TestAction" method="test"> <result name="test" type="dispatcher">/test.jsp</result> </action> </package>
3,redirect:表示重定向到jsp页面,设置较简单:
<package name="example" namespace="/user" extends="struts-default"> <action name="login" class="com.ljh.struts2.action.LoginAction" method="login"> <result name="success" type="redirect">/success.jsp</result> <result name="login">/login.jsp</result> </action> </package>
redirect也可以重定向到action,在重定向action时,不管action是否在同一个命名空间下,只要指定重定向action的完整路径即可,例如:
<package name="example" namespace="/user" extends="struts-default"> <action name="login" class="com.ljh.struts2.action.LoginAction" method="login"> <!-- 路径指定时需要增加合法的扩展名,但是项目中的扩展名一旦改变会影响我们的路径配置。 --> <result name="success" type="redirect">/user/test.action</result> <result name="login">/login.jsp</result> </action> <action name="test" class="com.ljh.struts2.action.TestAction" method="test"> <result name="test" type="redirect">/test.jsp</result> </action> </package>
4,redirectAction:专门用来重定向Action的。这个的设置和chain,专门用来转发action的设置一样,不在演示。
1,在配置文件以流的方式作为结果类型进行跳转,不同于上边的几种,例如:
<result name="success" type="stream"> <!-- 内容类型可以参照:CATALINA_HOME\conf\web.xml --> <param name="contentType">image/gif</param> <param name="inputName">imageStream</param> <param name="contentDisposition">attachment;filename="${filename}"</param> <param name="bufferSize">1024</param> </result>
2,在action中增加输入流属性,其名和配置文件中的要一样,一遍反射获取,还有就是文件名属性,
private String filename ;//获取文件名 private InputStream imageStream; // 读取下载的文件 //从WebRoot目录下读取文件 imageStream = ServletActionContext.getServletContext().getResourceAsStream("文件名");3,当然下载时 ,我们会先生成excel表格,或者其他office文档,进行处理,这是就涉及到JAVA和office的联合处理,这里给大家推荐一个很好用的第三方组件POI,进行对Office文档的生成。首先引进其jar包,这里几个简单例子:
//使用特殊的方式来操作Excle文档:(将生成的文档输出到缓冲区中) ByteArrayOutputStream baos = new ByteArrayOutputStream(); Workbook wb = getWorkBook(); wb.write(baos) ; //将文档对象数据生成到内存中(相当于存储到缓冲区中) imageStream = new ByteArrayInputStream(baos.toByteArray());
更多POI知识,请参考:POI百科 POI中文帮助文档
综上为页面相关内容的一些知识,主要是页面的跳转,下载跳转等,都是非常基础的知识,这里需要我们多看struts-default.xml文件中知识,通过了解其中的一些配置,以及其对应的类,是非常有意思的。