在weblogic上部署Jersey REST时出错(<bea-101216> <servlet:“restservlet”=“”failed =“”to =“”preload =“”on =“”startup =“”in =“”web =“” application:=“”“gateway”。)

时间:2018-04-26 05:59:04

标签: java rest jersey weblogic web-deployment

=“”

无法在weblogic服务器上部署jersey REST,是否有任何REST服务配置特定于weblogic?

完成堆栈跟踪 -

  

2018年4月25日下午7:01:53   com.sun.jersey.server.impl.application.WebApplicationImpl启动   信息:启动Jersey应用程序,版本'Jersey:1.2 05/07/2010   下午02:11',2018年4月25日下午7:01:53   com.sun.jersey.server.impl.application.WebApplicationImpl   processRootResources SEVERE:ResourceConfig实例没有   包含任何根资源类。 &lt; 25 Apr,2018 7:01:53 PM IST&gt;      (StubLifecycleHelper.java:48)     在   weblogic.servlet.internal.ServletStubImpl.prepareServlet(ServletStubImpl.java:539)     在   weblogic.servlet.internal.WebAppServletContext.preloadServlet(WebAppServletContext.java:1981)     在   weblogic.servlet.internal.WebAppServletContext.loadServletsOnStartup(WebAppServletContext.java:1955)     在   weblogic.servlet.internal.WebAppServletContext.preloadResources(WebAppServletContext.java:1874)     在   weblogic.servlet.internal.WebAppServletContext.start(WebAppServletContext.java:3155)     在   weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:1518)     在   weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:484)     在   weblogic.application.internal.flow.ModuleStateDriver $ 3.next(ModuleStateDriver.java:427)     在   weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:54)     在   weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:119)     在   weblogic.application.internal.flow.ScopedModuleDriver.start(ScopedModuleDriver.java:201)     在   weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:249)     在   weblogic.application.internal.flow.ModuleStateDriver $ 3.next(ModuleStateDriver.java:427)     在   weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:54)     在   weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:119)     在   weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java:28)     在   weblogic.application.internal.BaseDeployment $ 2.next(BaseDeployment.java:672)     在   weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:54)     在   weblogic.application.internal.BaseDeployment.activate(BaseDeployment.java:212)     在   weblogic.application.internal.EarDeployment.activate(EarDeployment.java:59)     在   weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:161)     在   weblogic.deploy.internal.targetserver.AppContainerInvoker.activate(AppContainerInvoker.java:79)     在   weblogic.deploy.internal.targetserver.BasicDeployment.activate(BasicDeployment.java:184)     在   weblogic.deploy.internal.targetserver.BasicDeployment.activateFromServerLifecycle(BasicDeployment.java:361)     在   weblogic.management.deploy.internal.DeploymentAdapter $ 1.doActivate(DeploymentAdapter.java:52)     在   weblogic.management.deploy.internal.DeploymentAdapter.activate(DeploymentAdapter.java:200)     在   weblogic.management.deploy.internal.AppTransition $ 2.transitionApp(AppTransition.java:31)     在   weblogic.management.deploy.internal.ConfiguredDeployments.transitionApps(ConfiguredDeployments.java:240)     在   weblogic.management.deploy.internal.ConfiguredDeployments.activate(ConfiguredDeployments.java:170)     在   weblogic.management.deploy.internal.ConfiguredDeployments.deploy(ConfiguredDeployments.java:124)     在   weblogic.management.deploy.internal.DeploymentServerService.resume(DeploymentServerService.java:181)     在   weblogic.management.deploy.internal.DeploymentServerService.start(DeploymentServerService.java:97)     在weblogic.t3.srvr.SubsystemRequest.run(SubsystemRequest.java:64)     在weblogic.work.ExecuteThread.execute(ExecuteThread.java:256)at   weblogic.work.ExecuteThread.run(ExecuteThread.java:221)

web.xml -

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
                         "http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
 <servlet>
  <servlet-name>FrontController</servlet-name>
  <display-name>FrontController</display-name>
  <description>Front Controller for handling requests</description>
  <servlet-class>com.obopay.icici.FrontController</servlet-class>
 </servlet>
 <servlet>
  <servlet-name>RestServlet</servlet-name>
  <display-name>RestServlet</display-name>
  <description>Rest Controller for handling http rest requests</description>
  <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
  <init-param>
   <param-name>com.sun.jersey.config.property.packages</param-name>
   <param-value>com.obopay.ebp.auth.resources</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
 </servlet>
 <servlet-mapping>
  <servlet-name>FrontController</servlet-name>
  <url-pattern>/siAuth</url-pattern>
 </servlet-mapping>
 <servlet-mapping>
  <servlet-name>FrontController</servlet-name>
  <url-pattern>*.do</url-pattern>
 </servlet-mapping>
 <servlet-mapping>
  <servlet-name>FrontController</servlet-name>
  <url-pattern>/failureResponse</url-pattern>
 </servlet-mapping>
 <servlet-mapping>
  <servlet-name>FrontController</servlet-name>
  <url-pattern>/successResponse</url-pattern>
 </servlet-mapping>
 <servlet-mapping>
  <servlet-name>RestServlet</servlet-name>
  <url-pattern>/*</url-pattern>
 </servlet-mapping>
 <session-config>
  <session-timeout>5</session-timeout>
 </session-config>
 <!-- Define an error handler for 404 pages -->
 <error-page>
  <error-code>404</error-code>
  <location>/jsp/error.jsp</location>
 </error-page>
 <!-- Define an error handler for java.lang.Throwable -->
 <error-page>
  <exception-type>java.lang.Throwable</exception-type>
  <location>/jsp/error.jsp</location>
 </error-page>
 <login-config>
  <auth-method>BASIC</auth-method>
 </login-config>
</web-app>

我正在使用以下罐子 -

jersey-bundle-1.2.jar
jsr311-api-1.1.1.jar
asm-3.1.jar
wlthint3client.jar
log4j-1.2.15.jar

1 个答案:

答案 0 :(得分:0)

解决!

问题不在于weblogic服务器,问题是我将源代码放在单独的文件夹而不是src中,所以weblogic无法在src文件夹中找到要扫描的包,所以在pom.xml中添加下面的插件后,部署成功 -

<plugin>
   <artifactId>maven-resources-plugin</artifactId>
   <version>3.0.2</version>
   <executions>
      <execution>
         <id>copy-source</id>
         <phase>generate-sources</phase>
         <goals>
            <goal>copy-resources</goal>
         </goals>
         <configuration>
            <outputDirectory>co/src</outputDirectory>
            <overwrite>true</overwrite>
            <resources>
               <resource>
                  <directory>${basedir}/co/EBP</directory>
               </resource>
            </resources>
         </configuration>
      </execution>
   </executions>
</plugin>

通过使用此插件,我将我的saperate文件夹源代码复制到src文件夹,覆盖为true。因此在src文件夹中提供了源代码。

通过在.classpath文件中提及源文件夹也可以解决此问题。