2014-01-07 3 views
-1

다음은 main() 메소드에있을 때 잘 작동하는 코드입니다. 컴파일 및 출력i/o 파일 쓰기 코드 오류

package com; 

import net.sf.jasperreports.engine.JRException; 
import net.sf.jasperreports.engine.JasperCompileManager; 

public class JasperCompile { 
    public static void main(String args[]) throws JRException { 
     JasperCompileManager.compileReportToFile("C:\\temp.jrxml", "C:\\temp.jasper"); 
    } 
} 

으로을 .jasper 파일을 제공하지만 서블릿의의 doGet 메소드 main() 메소드에서 행 다음에 삽입 할 때 그것은 스택 추적되어 다음

JasperCompileManager.compileReportToFile("C:\\temp.jrxml", "C:\\temp.jasper"); 

작동하지 않습니다.

Jan 7, 2014 4:19:21 PM org.apache.catalina.core.StandardWrapperValve invoke 
SEVERE: Servlet.service() for servlet [JasperReportsBrowserDemoServlet] in context with path [/PDFReports] threw exception [Servlet execution threw an exception] with root cause 
java.lang.NoSuchMethodError: org.apache.commons.digester.Digester.addSetProperties(Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/StringV 
at net.sf.jasperreports.components.ComponentsXmlHandler.addListRules(ComponentsXmlHandler.java:117) 
at net.sf.jasperreports.components.ComponentsXmlHandler.configureDigester(ComponentsXmlHandler.java:104) 
at net.sf.jasperreports.engine.xml.JRXmlDigesterFactory.addComponentRules(JRXmlDigesterFactory.java:514) 
at net.sf.jasperreports.engine.xml.JRXmlDigesterFactory.configureDigester(JRXmlDigesterFactory.java:493) 
at net.sf.jasperreports.engine.xml.JRXmlDigesterFactory.createDigester(JRXmlDigesterFactory.java:1324) 
at net.sf.jasperreports.engine.xml.JRXmlLoader.load(JRXmlLoader.java:207) 
at net.sf.jasperreports.engine.xml.JRXmlLoader.load(JRXmlLoader.java:172) 
at net.sf.jasperreports.engine.xml.JRXmlLoader.load(JRXmlLoader.java:156) 
at net.sf.jasperreports.engine.JasperCompileManager.compileReportToFile(JasperCompileManager.java:108) 
at com.JasperReportsBrowserDemoServlet.createJRXML(JasperReportsBrowserDemoServlet.java:136) 
at com.JasperReportsBrowserDemoServlet.doGet(JasperReportsBrowserDemoServlet.java:47) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:621) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:603) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
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:619) 
4:23 PM 

main() 메소드와 서버 측에서 코드를 작성할 때 어떤 차이가 있습니까?

+0

JasperReport의 버전은 무엇입니까? – esmoreno

+0

JasperReport의 버전이 올바르지 않으면 main() 메소드에서 실행될 때 출력이 왜 나는지? 두 프로그램 모두에 동일한 jar 파일을 사용하고 있습니다. – AmitG

답변

2

귀하의 Apache Commons Digester 버전이 잘못되었습니다. JasperReport의 모든 종속성을 검토하십시오.

+0

Apache Commons Digester가 올바르지 않으면 main() 메소드에서 실행될 때 출력이 왜 나는지? 두 프로그램 모두에 동일한 jar 파일을 사용하고 있습니다. – AmitG

+0

가능한 경우 classpath에 오류가 있습니다 (jar 또는 유사한 문제가 중복됩니다) – esmoreno

+0

서블릿으로 호출 할 때 서버가 다른 Apache Commons Digester 병을 사용하고 있습니다. 빠른 테스트를 위해 라이브러리를 웹 프로젝트의 lib 폴더에 넣고 다시 테스트하십시오. – esmoreno