2014-06-10 58 views
2

我是學生& JavaEE開發中的全新功能。我創建了一個獨立的EJB項目並在其中創建了Web服務。我正在使用Web服務WSDLJava Web應用程序項目中使用該服務。JavaEE:Web服務部署成功但測試人員不工作

當我部署EJB項目時,我得到了類似的東西。即成功部署。

Info: file:/media/benison/EXTRA/8th Sem Java Project/Projects/BusinessFacade/build/classes/_BusinessFacadePU logout successful 
Info: visiting unvisited references 
Info: visiting unvisited references 
Info: Entity.YearSemesterStudent actually got transformed 
Info: Entity.YearSemesterStudentPK actually got transformed 
Info: Entity.YearSemester actually got transformed 
Info: Entity.Student actually got transformed 
Info: Entity.CollegeCategory actually got transformed 
Info: Entity.Faculty actually got transformed 
Info: Entity.StudentMark actually got transformed 
Info: Entity.Exam actually got transformed 
Info: Entity.Setting actually got transformed 
Info: Entity.College actually got transformed 
Info: Entity.Subject actually got transformed 
Info: Entity.Contact actually got transformed 
Info: Entity.UserGroup actually got transformed 
Info: Entity.SubjectTeachingFaculty actually got transformed 
Info: Entity.SubjectTeachingFacultyPK actually got transformed 
Info: Entity.TeachingFaculty actually got transformed 
Info: Entity.DepartmentCourse actually got transformed 
Info: Entity.Event actually got transformed 
Info: Entity.News actually got transformed 
Info: Entity.Department actually got transformed 
Info: Entity.Employee actually got transformed 
Info: Entity.Course actually got transformed 
Info: Entity.UserType actually got transformed 
Info: Entity.User actually got transformed 
Info: EclipseLink, version: Eclipse Persistence Services - 2.5.0.v20130507-3faac2b 
Info: file:/media/benison/EXTRA/8th Sem Java Project/Projects/BusinessFacade/build/classes/_BusinessFacadePU login successful 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB UserRegistration: [java:global/BusinessFacade/UserRegistration!WebService.UserRegistration, java:global/BusinessFacade/UserRegistration] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB BLCollege: [java:global/BusinessFacade/BLCollege!EJB.BusinessLogic.IBLCollegeLocal, java:global/BusinessFacade/BLCollege] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB ALContact: [java:global/BusinessFacade/ALContact, java:global/BusinessFacade/ALContact!EJB.ApplicationLogic.IALContactLocal] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB ALSetting: [java:global/BusinessFacade/ALSetting, java:global/BusinessFacade/ALSetting!EJB.ApplicationLogic.IALSetting] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB BLFaculty: [java:global/BusinessFacade/BLFaculty!EJB.BusinessLogic.IBLFacultyLocal, java:global/BusinessFacade/BLFaculty] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB ALEvent: [java:global/BusinessFacade/ALEvent, java:global/BusinessFacade/ALEvent!EJB.ApplicationLogic.IALEventLocal] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB BLExam: [java:global/BusinessFacade/BLExam!EJB.BusinessLogic.IBLExamLocal, java:global/BusinessFacade/BLExam] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB BLSubject: [java:global/BusinessFacade/BLSubject!EJB.BusinessLogic.IBLSubjectLocal, java:global/BusinessFacade/BLSubject] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB ALUserGroup: [java:global/BusinessFacade/ALUserGroup!EJB.ApplicationLogic.IALUserGroupLocal, java:global/BusinessFacade/ALUserGroup] 
Warning: Container [email protected] doesn't support class com.sun.xml.ws.api.server.Module 
Info: EJB5181:Portable JNDI names for EJB BLStudent: [java:global/BusinessFacade/BLStudent!EJB.BusinessLogic.IBLStudentLocal, java:global/BusinessFacade/BLStudent] 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/BLExamService/ExamService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/BLSubjectService/SubjectService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/BLStudentService/StudentService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/ALUserGroupService/UserGroupService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/ALEventService/EventService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/ALSettingService/SettingService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/BLFacultyService/FacultyService 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/BLCollegeService/CollegeService 
Info: EJB Endpoint deployed Busines![enter image description here][1]sFacade 
    listening at address at http://benison-VirtualBox:8080/UserRegistration/UserRegistration 
Info: EJB Endpoint deployed BusinessFacade 
    listening at address at http://benison-VirtualBox:8080/ALContactService/ContactService 
Info: BusinessFacade was successfully deployed in 4,027 milliseconds. 


但是當我嘗試測試Web服務,它給了我下面的對話框:


enter image description here


和GlassFish日誌說:


Info: Invoking wsimport with http://localhost:8080/BLExamService/ExamService?WSDL 
Info: parsing WSDL... 
Info: [WARNING] schema_reference: Failed to read schema document 'ExamService?xsd=1', because 'http' access is not allowed due to restriction set by the accessExternalSchema property. 
Info: line 4 of http://localhost:8080/BLExamService/ExamService?WSDL#types?schema1 
Severe: service exception: 
java.lang.AssertionError:  org.xml.sax.SAXParseException; systemId: bundle://300.0:1/ com/sun/tools/xjc/reader/xmlschema/bindinfo/binding.xsd; lineNumber: 52; columnNumber: 88; schema_reference: Failed to read schema document 'xjc.xsd', because 'bundle' access is not allowed due to restriction set by the accessExternalSchema property. 
at  com.sun.tools.xjc.SchemaCache.newValidator(SchemaCache.java:80) 
at  com.sun.tools.xjc.reader.internalizer.SCDBasedBindingSet.apply(SCDBasedBindingSet.java:237) 
at  com.sun.tools.xjc.ModelLoader.createXSOM(ModelLoader.java:541) 
at  com.sun.tools.xjc.api.impl.s2j.Schema compilerImpl.bind(Schema compilerImpl.java:269) 
at  com.sun.tools.xjc.api.impl.s2j.Schema compilerImpl.bind(Schema compilerImpl.java:95) 
at  com.sun.tools.ws.processor.modeler.wsdl.JAXBModelBuilder.bind(JAXBModelBuilder.java:142) 
at  com.sun.tools.ws.processor.modeler.wsdl.WSDLModeler.buildJAXBModel(WSDLModeler.java:2298) 
at  com.sun.tools.ws.processor.modeler.wsdl.WSDLModeler.internalBuildModel(WSDLModeler.java:198) 
at  com.sun.tools.ws.processor.modeler.wsdl.WSDLModeler.buildModel(WSDLModeler.java:141) 
at  com.sun.tools.ws.ws compile.WsimportTool.buildWsdlModel(WsimportTool.java:444) 
at  com.sun.tools.ws.ws compile.WsimportTool.run(WsimportTool.java:205) 
at  com.sun.tools.ws.ws compile.WsimportTool.run(WsimportTool.java:183) 
at  com.sun.tools.ws.util.WSToolsObjectFactoryImpl.wsimport(WSToolsObjectFactoryImpl.java:60) 
at  com.sun.tools.ws.spi.WSToolsObjectFactory.wsimport(WSToolsObjectFactory.java:88) 
at  org.glassfish.webservices.monitoring.WebServiceTesterServlet.wsImport(WebServiceTesterServlet.java:642) 
at  org.glassfish.webservices.monitoring.WebServiceTesterServlet.initializePort(WebServiceTesterServlet.java:528) 
at  org.glassfish.webservices.monitoring.WebServiceTesterServlet.doGet(WebServiceTesterServlet.java:169) 
at  org.glassfish.webservices.monitoring.WebServiceTesterServlet.invoke(WebServiceTesterServlet.java:104) 
at  org.glassfish.webservices.EjbWebServiceServlet.service(EjbWebServiceServlet.java:136) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790) 
at  org.glassfish.grizzly.servlet.ServletHandler.doServletService(ServletHandler.java:242) 
at  org.glassfish.grizzly.servlet.ServletHandler.service(ServletHandler.java:193) 
at  com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:246) 
at  org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191) 
at  org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168) 
at  org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189) 
at  org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119) 
at  org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288) 
at  org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206) 
at  org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136) 
at  org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114) 
at  org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77) 
at  org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838) 
at  org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113) 
at  org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115) 
at  org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55) 
at  org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135) 
at  org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564) 
at  org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544) 
at java.lang.Thread.run(Thread.java:745) 
Caused by:  org.xml.sax.SAXParseException; systemId: bundle://300.0:1/ com/sun/tools/xjc/reader/xmlschema/bindinfo/binding.xsd; lineNumber: 52; columnNumber: 88; schema_reference: Failed to read schema document 'xjc.xsd', because 'bundle' access is not allowed due to restriction set by the accessExternalSchema property. 
at  com.sun. org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:203) 
at  com.sun. org.apache.xerces.internal.util.ErrorHandlerWrapper.fatalError(ErrorHandlerWrapper.java:177) 
at  com.sun. org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:441) 
at  com.sun. org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaErr(XSDHandler.java:4162) 
at  com.sun. org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaFatalError(XSDHandler.java:4141) 
at  com.sun. org.apache.xerces.internal.impl.xs.traversers.XSDHandler.getSchemaDocument(XSDHandler.java:2168) 
at  com.sun. org.apache.xerces.internal.impl.xs.traversers.XSDHandler.resolveSchema(XSDHandler.java:2078) 
at  com.sun. org.apache.xerces.internal.impl.xs.traversers.XSDHandler.constructTrees(XSDHandler.java:1008) 
at  com.sun. org.apache.xerces.internal.impl.xs.traversers.XSDHandler.parseSchema(XSDHandler.java:620) 
at  com.sun. org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadSchema(XMLSchemaLoader.java:616) 
at  com.sun. org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadGrammar(XMLSchemaLoader.java:574) 
at  com.sun. org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadGrammar(XMLSchemaLoader.java:540) 
at  com.sun. org.apache.xerces.internal.jaxp.validation.XMLSchemaFactory.newSchema(XMLSchemaFactory.java:255) 
at javax.xml.validation.SchemaFactory.newSchema(SchemaFactory.java:638) 
at javax.xml.validation.SchemaFactory.newSchema(SchemaFactory.java:670) 
at  com.sun.tools.xjc.SchemaCache.newValidator(SchemaCache.java:77) 
... 39 more 


所以我堅持在這裏像永遠。任何人都可以提出一些建議,比如可能是什麼問題以及爲什麼會發生這種情況。任何提示都會有所幫助。

編輯:

我也試圖訪問我的WSDL如下圖所示,它返回WSDL的XML,如下圖所示:


enter image description here


然後我試圖直接訪問測試儀,但是這會發生什麼:


enter image description here

同樣適用於所有的Web服務。他們都沒有工作。

注:我使用@WebService(NAME = 「<服務名稱>」)標註使用EJB的我爲Web服務創建。

回答

3

朋友我得到了我的問題的解決方案......


這是問題可能是在Java SDK 7的用戶面臨(與最新的更新)或Java SDK 8.

當這問題出現了,你可以使用以下步驟:

步驟1:修改IDE配置文件(的netbeans.conf)以下開關添加到netbeans_default_options。

-J-Djavax.xml.accessExternalSchema =所有

              注:你可以找到的netbeans.conf文件中$ {NB-安裝}/etc/目錄。 more info

步驟2:打開GlassFish配置文件並添加以下JVM選項元素。您將需要重新啓動服務器才能使更改生效。

< Java的配置>
                ...
                < JVM選項> -Djavax.xml.accessExternalSchema =所有</JV米選項>
</java的配置>


步驟3:創建一個名爲文件jaxp.properties(如果它不存在)下/路徑/to/jdk1.8.0/jre/lib然後在其中寫下此行:

javax.xml。accessExternalSchema =所有


我從以下鏈接此解決方案:

2

我想你需要的東西,如更新GlassFish服務器的domain.xml中文件:

</java-config> 
    ... 
    <jvm-options>-Djavax.xml.accessExternalSchema=all</jvm-options> 
</java-config> 

其他一些設置也可能有許多工作要做。有關更多信息,請參見https://netbeans.org/kb/docs/websvc/jax-ws.html。希望能幫助到你!!

+0

感謝您的幫助Gurminder。我做了同樣的事情,遵循鏈接中提供的每個指示,更改了默認在jdk 8中禁用的conf設置,重新啓動了netbeans&glassfish,並且重建和重新部署了EJB項目,但仍然存在錯誤。 Kya karoon yaar ..? –

+0

您是否更改了IDE(NetBeans)以及Glassfish的設置? –

+0

是的,我在Nebeans.conf&in domain.xml中都做過。 –

0

您是否仔細閱讀了您的玻璃魚堆棧跟蹤?

 [WARNING] schema_reference: Failed to read schema document 'ExamService?xsd=1', because 'http' access is not allowed due to restriction set by the accessExternalSchema property 

看起來像'http'訪問是不允許的,必須在SSL協議上工作。

相關問題