问题描述
最近有一个web项目,之前是在tomcat下运行,现在要切换到WebSphere下面,由于程序初始化代码放在了filter里面,启动WAS服务时并没有初始化filter,而是在第一次访问时才初始化filter。这样就导致启动服务时Servlet里访问初始化数据(如对象初始化、缓存数据等)时直接报错。
问题原因
使用tomcat部署web项目,加载顺序为context-param>listener>filter>servlet。所有的filter都会在Servlet之前加载。所以tomcat下,在Servlet里可以访问filter里初始化的数据。
而使用WebSphere部署web项目时,filter并没有在Servlet之前初始化filter。
所以,只要能让filter在Servlet初始化之前初始化即可。解决方法如下:
解决方法
在网上找了很长时间,最后发现WebSphere Application Server有两个属性(com.ibm.ws.webcontainer.initFilterBeforeInitServlet和com.ibm.ws.webcontainer.invokeFilterInitAtStartup),设置为true即可。设置方法如下:
1、打开WebSphere控制台,服务器—>服务器类型—>WebSphere Application Server,在右侧进入相应的服务,如下图:
2、点击右侧的Web容器设置—>Web容器,如下图:
3、点击右侧定制属性,然后添加com.ibm.ws.webcontainer.initFilterBeforeInitServlet和com.ibm.ws.webcontainer.invokeFilterInitAtStartup 定制属性,属性值都为true,如下图:
4、重启WebSphere Server和项目服务,之后便会和tomcat下一样按context-param>listener>filter>servlet的顺序加载初始化。
Web容器定制属性
com.ibm.ws.webcontainer.initFilterBeforeInitServlet
描述:根据名称编可以看出其作用,即在初始化Servlet之前初始化filter。
默认值:false
注意:为了避免麻烦,最好同时设置com.ibm.ws.webcontainer.invokeFilterInitAtStartup和com.ibm.ws.webcontainer.initFilterBeforeInitServlet。
com.ibm.ws.webcontainer.invokeFilterInitAtStartup
描述:在服务启动的时候,调用filter的初始化对filter进行初始化。
默认值:false
原文链接:https://blog.csdn.net/gnail_oug/article/details/61918929