แอปพลิเคชัน Jersey ไม่ทำงานบน WebLogic

ฉันมีแอปพลิเคชันที่ทำงานได้ดีเมื่อฉันปรับใช้บนเซิร์ฟเวอร์ Tomcat แต่ไม่ทำงานหากใช้งานบนเว็บลอจิก
เวอร์ชัน Tomcat คือ: 7.0.47
เวอร์ชันของ Weblogic คือ: 12.2.1.2.0

มีจุดสิ้นสุดส่วนที่เหลือแบบง่ายที่ส่งคืน JSON:
http://localhost:8080/MyApplication/rest/configuration/test
ทำงานได้ดีบน Tomcat บนเว็บลอจิกฉันได้รับเฉพาะสตริง "Not Found"

ในไฟล์บันทึกคำเตือนเดียวที่ฉันพบมีดังต่อไปนี้:

<Warning> <JAXRSIntegration> <MyApplication> <[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <24ad6e0e-7bbc-4781-b294-f546069677ec-00000007> <1511013418859> <[severity-value: 16] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-2192510> <Cannot add Jersey servlet for application class org.glassfish.jersey.server.ResourceConfig because ApplicationPath annotation is not set on it.>
<Warning> <JAXRSIntegration> <MyApplication> <[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <24ad6e0e-7bbc-4781-b294-f546069677ec-00000007> <1511013418860> <[severity-value: 16] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-2192510> <Cannot add Jersey servlet for application class org.glassfish.jersey.server.ResourceConfig$WrappingResourceConfig because ApplicationPath annotation is not set on it.>
<Warning> <JAXRSIntegration> <MyApplication> <[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <24ad6e0e-7bbc-4781-b294-f546069677ec-00000007> <1511013418861> <[severity-value: 16] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-2192510> <Cannot add Jersey servlet for application class org.glassfish.jersey.server.ResourceConfig$RuntimeConfig because ApplicationPath annotation is not set on it.>

จุดสิ้นสุด:

@Path("/configuration")
@NoCache
public class ConfigurationResource {
    @GET
    @Path("/test")
    @Produces(MediaType.APPLICATION_JSON)
    public Response getClientConfig() {
        Map<String, Object> map = new HashMap<>();
        map.put("test", "Test is running.");
        return Response.ok(map).build();
    }

    ...
}
public class MyApplication extends ResourceConfig {
    public MyApplication() {
        register(ConfigurationResource.class);
    }
}

จากเว็บ.xml

<servlet>
    <servlet-name>jersey-servlet</servlet-name>
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
    <init-param>
        <param-name>javax.ws.rs.Application</param-name>
        <param-value>com.sample.rest.MyApplication</param-value>
    </init-param>
    <init-param>
        <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
        <param-value>true</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>jersey-servlet</servlet-name>
    <url-pattern>/rest/*</url-pattern>
</servlet-mapping>

เว็บลอจิก.xml:

<weblogic-web-app>
    <container-descriptor>
        <prefer-application-packages>
          <package-name>javax.ws.rs</package-name>
          <package-name>javax.persistence</package-name>
          <package-name>org.apache.commons</package-name>
          <package-name>org.slf4j</package-name>
          <package-name>org.apache.commons.logging</package-name>
          </prefer-application-packages>
    </container-descriptor>
</weblogic-web-app>

ฉันได้ลองเพิ่มคำอธิบายประกอบแล้วแต่ไม่มีผลใดๆ
มีใครทราบบ้างว่าฉันจะทำอย่างไรเพื่อให้มันใช้งานได้


person PaulEdison    schedule 18.11.2017    source แหล่งที่มา
comment
ไม่แน่ใจว่าคุณได้เพิ่ม @ApplicationPath("/MyApplication") ในชั้นเรียน MyApplication หรือไม่   -  person Optional    schedule 18.11.2017
comment
@ทางเลือก: ใช่นั่นคือสิ่งที่ฉันพยายาม (เพราะฉันคิดว่านั่นคือสิ่งที่ขาดหายไปสำหรับเว็บลอจิก) แต่นั่นก็ไม่มีผลกระทบต่อคำเตือนและฟังก์ชันการทำงาน ที่น่ารำคาญคือไม่มีคำเตือน/ข้อผิดพลาดอื่น ๆ ที่จะเข้าใจว่าปัญหาคืออะไร   -  person PaulEdison    schedule 20.11.2017


คำตอบ (1)


ฉันพบวิธีแก้ปัญหาสำหรับปัญหานั้นหลังจากลบบางบรรทัดออกจาก weblogic.xml ที่ใช้งานได้:

เว็บลอจิก.xml:

<weblogic-web-app>enter code here
    <container-descriptor>
        <prefer-application-packages>

          <package-name>org.apache.commons</package-name>
          <package-name>org.slf4j</package-name>
          <package-name>org.apache.commons.logging</package-name>
          </prefer-application-packages>
    </container-descriptor>
</weblogic-web-app>

ดังนั้นฉันจึงลบ:

          <package-name>javax.ws.rs</package-name>
          <package-name>javax.persistence</package-name>

นี่เป็นสิ่งเดียวเท่านั้น น่าเสียดายที่ไม่มีคำแนะนำที่แท้จริงว่าปัญหาที่แท้จริงคืออะไร เนื่องจากฉันไม่พบรายการข้อผิดพลาด/คำเตือนในไฟล์บันทึกใดๆ

ดูเหมือนว่าแพ็คเกจเหล่านี้เข้ากันไม่ได้กับแพ็คเกจที่จัดทำโดยเว็บลอจิก ฉันคิดว่าควรตรวจสอบด้วยว่าการขึ้นต่อกันในไฟล์ pom อยู่ในขอบเขต 'ให้มา' หรือไม่

person PaulEdison    schedule 26.11.2017