2011-02-10 6 views
8

배포 환경 : Windows Server 2008, Tomcat 7.0.5, Oracle JRE 1.6. Eclipse Helios와 동일한 개발 환경.OpenSAML 부트 스트랩()이 "InputStream은 null이 될 수 없습니다."

OpenSAML 2.3.1을 사용하는 Java 응용 프로그램을 배포하고 테스트하려고하면 실행되지 않습니다. 소스 코드와 스택 추적을 살펴보면 DefaultBootstrap.bootstrap()java.lang.IllegalArgumentException: InputStream cannot be null이됩니다. 아래에 전체 스택 추적을 포함합니다.

대상 배포 시스템의 소프트웨어 버전은 모든 것이 잘 실행되는 개발 상자와 동일하거나 적어도 같아야합니다. 물론 .war를 사용하여 배포하지 않습니다. . 배포 아카이브에서 일부 XML 또는 DTD 파일이 누락되었다는 느낌이 들지만 그 느낌만으로도 해결할 수 없습니다. stacktrace의 일부에 대한 인터넷 검색도별로 도움이되지 않았습니다.

어디에서이 오류의 실제 근본 원인을 추적 할 수 있습니까? 문제를 해결할 수 있습니까?

private PersedResponse() throws ConfigurationException { 
    DefaultBootstrap.bootstrap(); // line 56 
    ... 

동일한 파일에서 라인 (104) 반면,이 전용 기본 호출 외부에서 호출되는 생성자이다

2011-feb-10 10:56:08 org.apache.catalina.core.StandardWrapperValve invoke 
ALLVARLIG: Servlet.service() for servlet [se.novasoftware.gabriel.SAMLParser] in context with path [/ServiceTier] threw exception [java.lang.IllegalArgumentException: InputStream cannot be null] with root cause 
java.lang.IllegalArgumentException: InputStream cannot be null 
at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:120) 
at org.opensaml.xml.parse.BasicParserPool$DocumentBuilderProxy.parse(BasicParserPool.java:643) 
at org.opensaml.xml.parse.BasicParserPool.parse(BasicParserPool.java:216) 
at org.opensaml.xml.XMLConfigurator.load(XMLConfigurator.java:141) 
at org.opensaml.DefaultBootstrap.initializeXMLTooling(DefaultBootstrap.java:148) 
at org.opensaml.DefaultBootstrap.bootstrap(DefaultBootstrap.java:88) 
at _mynamespace_.saml.ParsedResponse.<init>(ParsedResponse.java:56) 
at _mynamespace_.saml.ParsedResponse.<init>(ParsedResponse.java:104) 
at _mynamespace_.SAMLParser.doPost(SAMLParser.java:29) // servlet entry point 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:306) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:108) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:379) 
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243) 
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:259) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:281) 
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 
at java.lang.Thread.run(Thread.java:662) 

ParsedResponse.java 라인 (56)은 그 생성자에 부트 스트랩() 호출이다 생성자 :

public ParsedResponse(final String samlXML) 
     throws UnmarshallingException, ConfigurationException { 
    this(); // line 104 
    ... 

답변

19

openws-1.3.0.jar을 배포 어셈블리에 추가하면 트릭을 만들었습니다.