Война весенней загрузки на Weblogic 12c

У меня возникают ошибки во время развертывания с Spring-boot 2.1.2.RELEASE на WebLogic 12.2.1.2.0.

Это трассировка стека:

Caused By: java.lang.IllegalAccessError: tried to access method com.fasterxml.jackson.databind.ser.std.StdSerializer.<init>(Ljava/lang/Class;)V from class com.fasterxml.jackson.datatype.jsr310.JavaTimeModule
at com.fasterxml.jackson.datatype.jsr310.JavaTimeModule.<init>(JavaTimeModule.java:168)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:172)
at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:122)
at org.springframework.http.converter.json.Jackson2ObjectMapperBuilder.registerWellKnownModulesIfAvailable(Jackson2ObjectMapperBuilder.java:760)
at org.springframework.http.converter.json.Jackson2ObjectMapperBuilder.configure(Jackson2ObjectMapperBuilder.java:639)
at org.springframework.http.converter.json.Jackson2ObjectMapperBuilder.build(Jackson2ObjectMapperBuilder.java:623)
at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.<init>(MappingJackson2HttpMessageConverter.java:59)
at org.springframework.http.converter.support.AllEncompassingFormHttpMessageConverter.<init>(AllEncompassingFormHttpMessageConverter.java:76)
at org.springframework.web.filter.FormContentFilter.<init>(FormContentFilter.java:60)
at org.springframework.boot.web.servlet.filter.OrderedFormContentFilter.<init>(OrderedFormContentFilter.java:29)
at org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration.formContentFilter(WebMvcAutoConfiguration.java:166)

Я попытался добавить это в weblogic.xml:

  <wls:package-name>com.fasterxml.*</wls:package-name>
      <wls:package-name>com.fasterxml.jackson.databind.*</wls:package-name>
      <wls:package-name>com.fasterxml.jackson.*</wls:package-name>
      <wls:package-name>com.fasterxml.jackson.datatype.jsr310.*</wls:package-name>
      <wls:package-name>com.fasterxml.jackson.datatype.*</wls:package-name>
      <wls:package-name>com.fasterxml.jackson.module.*</wls:package-name>

Я также пытался использовать классы preference-web-inf. Класс StdSerializer находится в jar-файле jackson-datatype-jsr310:2.9.8, что теоретически не должно быть проблемой, поскольку в welogic не включен Джексон. Любая помощь будет оценена по достоинству.


person khhaaannnnn    schedule 06.02.2019    source источник


Ответы (1)


1) Оставьте в файле weblogic.xml только эти пакеты, остальные не нужны:

<wls:prefer-application-packages>
    <wls:package-name>org.slf4j.*</wls:package-name>
    <wls:package-name>org.springframeworks.*</wls:package-name>
    <wls:package-name>com.fasterxml.jackson.*</wls:package-name>
</wls:prefer-application-packages>

2) Включите это в свой pom.xml в соответствии с Документы Spring, раздел 92.1:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-tomcat</artifactId>
    <scope>provided</scope>
</dependency>

Эта ошибка возникает из-за того, что Spring Boot пытается запустить контейнер Tomcat, вызывая конфликты путей к классам. Установка зависимости, как указано, удалит большинство из них, а включение com.fasterxml.jackson.* в ваш weblogic.xml позаботится об оставшемся конфликте.

person Daniel Pereira    schedule 20.03.2019