java - 无法读取struts2拦截器中的属性文件

标签 java struts2

我定义了一个拦截器和一个拦截器堆栈,如下所示:

<package name="interceptor" extends="struts-default">
    <interceptors>
        <interceptor name="log"
            class="com.log.LogInterceptor" />
        <interceptor-stack name="interceptorStack">
            <interceptor-ref name="defaultStack" />
            <interceptor-ref name="log" />
        </interceptor-stack>
    </interceptors>

    <default-interceptor-ref name="interceptorStack" />
</package>

LogInterceptor类是这样的:

package com.log;

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

public class LogInterceptor extends AbstractInterceptor {

private static final long serialVersionUID = 1L;
private Properties prop;

@Override
public void init() {
    InputStream in = Object.class.getResourceAsStream( "/com/log/interceptor.properties" );
    try {
        prop.load( in );
    } catch (IOException e) {
        e.printStackTrace();
    }
    System.out.println( "init" );
}

@Override
public String intercept(ActionInvocation invocation) throws Exception {
    String actionName = invocation.getInvocationContext().getName();
    System.out.println( actionName );
    long startTime = System.currentTimeMillis();
    invocation.invoke();
    long endTime = System.currentTimeMillis();
    System.out.println( endTime - startTime );
    return null;
}
}

我想在 init() 中读取属性文件。但是当我启动 tomcat 时,我得到这个:

Caught Exception while registering Interceptor class com.log.LogInterceptor - interceptor - file:/C:/Program%20Files/Apache%20Software%20Foundation/Tomcat%206.0/webapps/EnergySystem/WEB-INF/classes/struts.xml:28:50
at org.apache.struts2.impl.StrutsObjectFactory.buildInterceptor(StrutsObjectFactory.java:77)
at com.opensymphony.xwork2.config.providers.InterceptorBuilder.constructInterceptorReference(InterceptorBuilder.java:70)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.lookupInterceptorReference(XmlConfigurationProvider.java:1043)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadInterceptorStack(XmlConfigurationProvider.java:860)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadInterceptorStacks(XmlConfigurationProvider.java:873)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadInterceptors(XmlConfigurationProvider.java:896)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.addPackage(XmlConfigurationProvider.java:476)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadPackages(XmlConfigurationProvider.java:286)
at org.apache.struts2.config.StrutsXmlConfigurationProvider.loadPackages(StrutsXmlConfigurationProvider.java:112)
at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:234)
at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)
at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:390)
at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:437)
at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:74)
at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)
at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:295)
at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:422)
at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:115)
at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4072)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4726)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601)
at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:675)
at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:601)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:502)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1317)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:324)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1065)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)
at org.apache.catalina.core.StandardService.start(StandardService.java:525)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)
at org.apache.catalina.startup.Catalina.start(Catalina.java:595)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Caused by: java.lang.NullPointerException
at com.log.LogInterceptor.init(LogInterceptor.java:29)
at org.apache.struts2.impl.StrutsObjectFactory.buildInterceptor(StrutsObjectFactory.java:57)
... 41 more

读取属性的代码看起来是正确的,因为如果我将此代码放在其他类中并在 main() 中调用它,我可以成功读取文件。我想知道为什么它会在 init() 中失败。请帮助我,谢谢!

解决方案:我太粗心了,没有实例化 prop,现在我做了 Properties prop = new Properties() 然后我使用 LogInterceptor.class.getResourceAsStream。然后它就可以了!谢谢!

最佳答案

尝试使用您的类而不是 Object 类来加载资源。

LogInterceptor.class.getResourceAsStream("interceptor.properties");

关于java - 无法读取struts2拦截器中的属性文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15378473/

相关文章:

java - JSTL 迭代列表

java - 我可以使用递归来简化这个过程吗?

java - 阻止从 JSP 访问 WEB-INF

java - 如何禁用tomcat服务器控制台日志?

java - 使用struts在java中配置网站电子邮件

java - 返回到 Struts 2 中输入结果的当前页面

javascript - 如何在 URL 构建中转义 & 运算符

java - 如何使用注释链接自定义拦截器

java - lambda 表达式的序列化有哪些安全风险?

java - 当 Eden 未满时发生 Minor GC。当Eden未满时,会出现Minor GC的原因是什么?