前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >struts2在web.xml中配置详情

struts2在web.xml中配置详情

作者头像
全栈程序员站长
发布2022-07-10 10:46:13
4130
发布2022-07-10 10:46:13
举报

大家好,又见面了,我是全栈君。

web.xml是web应用中载入有关servlet信息的重要配置文件,起着初始化servlet,filter等web程序的作用。

通常,全部的MVC框架都须要Web应用载入一个核心控制器。那採取什么方法载入这种核心控制器呢,servlet或filter成为了非常好的选择。 由于它们会随着web服务的启用而自己主动的载入。

对于Struts 2框架而言。须要载入FilterDispatcher, 仅仅要Web应用负责载入FilterDispatcher,FilterDispatcher将会载入应用的Struts 2框架。

由于Struts 2将核心控制器设计成Filter。而不是一个普通Servlet。

故为了让Web应用载入FilterDispacher。仅仅须要在web.xml文件里配置FilterDispatcher就可以。

在web.xml里面配置struts。假设是2.1.3之前的版本号,用 org.apache.struts2.dispatcher.FilterDispatcher。 以后的版本号则配置org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter。

<!– 配置Struts 2框架的核心Filter –> <filter> <!– 配置Struts 2核心Filter的名字 –> <filter-name>struts2</filter-name> <!– 配置Struts 2核心Filter的实现类 –> <filter-class>org.apache.struts2.dispatcher.FilterDispatcher </filter-class>

FilterDispatcher API 写道

Deprecated. Since Struts 2.1.3, use StrutsPrepareAndExecuteFilter instead or StrutsPrepareFilter and StrutsExecuteFilter if needing using the ActionContextCleanUp filter in addition to this one

FilterDispatcher是struts2.0.x到2.1.2版本号的核心过滤器.! StrutsPrepareAndExecuteFilter是自2.1.3開始就替代了FilterDispatcher的.! {org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter}

<init-param> <param-name>config </param-name> <param-value>struts-default.xml,struts-plugin.xml,/WEB-INF/struts.xml </param-value> </init-param>

<init-param> <!– 配置Struts 2框架默认载入的Action包结构 –> <param-name>actionPackages</param-name> <param-value>org.apache.struts2.showcase.person</param-value> </init-param>

<!– 配置Struts 2框架的配置提供者类 –> <init-param> <param-name>configProviders </param-name> <param-value>lee.MyConfigurationProvider</param-value> </init-param> <!– 配置Struts 2框架的常量 –> <init-param> <param-name>truts.enable.DynamicMethodInvocation</param-name> <param-value>false</param-value> </init-param> <init-param> <param-name>struts.devMode</param-name> <param-value>false</param-value> </init-param> <init-param> <param-name>struts.objectFactory</param-name> <param-value>spring</param-value> </init-param>

</filter> <!– 配置Filter拦截的URL –> <filter-mapping> <!– 配置Struts 2的核心FilterDispatcher拦截全部用户请求 –> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>

当中有3个初始化參数有特殊意义: config:该參数的值是一个以英文逗号(,)隔开的字符串,每一个字符串都是一个XML配置文件的位置。

Struts 2框架将自己主动载入该属性指定的系列配置文件。

假设没有指定该属性则默认使用例如以下三个配置文件struts-default.xml,struts-plugin.xml,struts.xml actionPackages:该參数的值也是一个以英文逗号(,)隔开的字符串。每一个字符串都是一个包空间,Struts 2框架将扫描这些包空间下的Action类。 configProviders:假设用户须要实现自己的ConfigurationProvider类,用户能够提供一个或多个实现了ConfigurationProvider接口的类。 然后将这些类的类名设置成该属性的值。多个类名之间以英文逗号(,)隔开。 除此之外,还可在此处配置Struts 2常量,每一个<init-param>元素配置一个Struts 2常量,当中<param-name>子元素指定了常量name, 而<param-value>子元素指定了常量value。

至于filter-mapping属性是过滤器(Filter)必须的一个属性,用于过滤请求的路径,此处一般就设为/*形式, 对全部请求uri进行拦截(过滤),除非你要做一些特殊的处理。

到此,配置完struts2的核心控制器后,基本完毕了struts2在web.xml文件里的配置。

注意点:假设web容器是J2EE1.3(servlet2.3),因为不会自己主动载入struts的标签库,所以须要在web.xml文件里手动载入struts的标签库。 文件名称struts-tags.tld,一般放在WEB-INF以下,能够自己指定但假设web容器是J2EE1.4(servlet2.4),那么web容器会自己主动载入标签库, Struts 2的标签库定义文件包括在struts2-core-2.0.6.jar文件中,在struts2-core-2.0.6.jar文件的META-INF路径下。包括了一个struts-tag.tld文件, 这个文件就是Struts 2的标签库定义文件,Servlet 2.4规范会自己主动载入该标签库文件,当中struts-tags.tld文件中包括了载入信息的片断:例如以下: <taglib> <!– 定义标签库的版本号 –> <tlib-version>2.2.3</tlib-version> <!– 定义标签库所需的JSP版 –> <jsp-version>1.2</jsp-version> <short-name>s</short-name> <!– 定义Struts 2标签库的URI。jsp文件里应用的uri–> <uri>/struts-tags</uri>… </taglib> 而servlet2.3手动配置例如以下: <!– 手动配置Struts 2的标签库 –> <taglib> <!– 配置Struts 2标签库的URI jsp文件里应用的uri,类似于名字空间–> <taglib-uri>/s</taglib-uri> <!– 指定Struts 2标签库定义文件的物理位置 –> <taglib-location>/WEB-INF/struts-tags.tld</taglib-location> </taglib>

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/115663.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年2月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档