SpringFox Swagger не работает должным образом на IBM Liberty 19.0.0.1 - PullRequest
0 голосов
/ 09 марта 2019

Прилагается ниже (Swagger на Tomcat) (нажмите, чтобы увеличить масштаб) - Пользовательский интерфейс Swagger моего приложения на Tomcat 9 enter image description here

В приложении (Swagger on Liberty) (нажмите, чтобы увеличить масштаб) - Пользовательский интерфейс Swagger моего приложения на Liberty 19.0.0.1 enter image description here

В Tomcat, как можно видеть, тело ответа 200 четко показано, а выполнение опции "Попробуйте" безупречно.

Однако в Liberty тело ответа 200 не отображается, и в результате выполнения «Попробуйте это» тело ответа, заполненное ошибками, выглядит следующим образом (усечено):

<H1>Error Page Exception</H1>
<H4>SRVE0260E: The server cannot use the error page specified for your application to handle the Original Exception printed below.</H4>
<BR><H3>Original Exception: </H3>
<B>Error Message: </B>Unauthorized<BR>
<B>Error Code: </B>401<BR>
<B>Target Servlet: </B>dispatcherServlet<BR>
<B>Error Stack: </B><BR>
com.ibm.ws.webcontainer.webapp.WebAppErrorReport: Unauthorized

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at com.ibm.ws.webcontainer.webapp.WebAppDispatcherContext.sendError(WebAppDispatcherContext.java:630)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at com.ibm.ws.webcontainer.webapp.WebAppDispatcherContext.sendError(WebAppDispatcherContext.java:648)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at com.ibm.ws.webcontainer.srt.SRTServletResponse.sendError(SRTServletResponse.java:1328)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at javax.servlet.http.HttpServletResponseWrapper.sendError(HttpServletResponseWrapper.java:164)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at javax.servlet.http.HttpServletResponseWrapper.sendError(HttpServletResponseWrapper.java:164)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.util.OnCommittedResponseWrapper.sendError(OnCommittedResponseWrapper.java:119)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.authentication.www.BasicAuthenticationEntryPoint.commence(BasicAuthenticationEntryPoint.java:61)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.authentication.DelegatingAuthenticationEntryPoint.commence(DelegatingAuthenticationEntryPoint.java:95)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.access.ExceptionTranslationFilter.sendStartAuthentication(ExceptionTranslationFilter.java:213)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.access.ExceptionTranslationFilter.handleSpringSecurityException(ExceptionTranslationFilter.java:185)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:141)

<BR>&nbsp;&nbsp;&nbsp;&nbsp;
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:334)
...
...
more

В то же время консоль Liberty имеет следующую ошибку (перейдите к пункту справа):

Error reported: 406

[ERROR   ] Error Page Exception:
                                                                                                               0-0

                                                                                                               Error Page Exception
                                                                                                               com.ibm.ws.webcontainer.webapp.WebAppErrorReport: SRVE0295E

Файл server.xml моей Liberty выглядит следующим образом:

<?xml version="1.0" encoding="UTF-8"?>
<server description="new server">

    <!-- Enable features -->
    <featureManager>
        <feature>webProfile-8.0</feature>
        <feature>springBoot-2.0</feature>
        <feature>servlet-4.0</feature>
    </featureManager>

    <basicRegistry/>

    <!-- To access this server from a remote client add a host attribute to the following element, e.g. host="*" -->
    <httpEndpoint id="defaultHttpEndpoint"
                  httpPort="9090"
                  httpsPort="9443" />

    <!-- Automatically expand WAR files and EAR files -->
    <applicationManager autoExpand="true"/>

</server>

Мое приложение использует Java 8, Spring Boot (2.1.3) с Spring Integration, Spring Security, Spring REST Docs, Springfox 3.0.0-SNAPSHOT и Log4j 2.

Может ли кто-нибудь помочь указать на основную причину, по которой Liberty не может отобразить ответ Swagger или предоставить возможность "попробовать его"? Как я уже сказал, то же самое слаженно работает на Tomcat 9.

С уважением, Бхарат

1 Ответ

1 голос
/ 12 марта 2019

Эта проблема может быть связана с развертыванием приложения SpringBoot 2.1.3 в Liberty 19.0.0.1, которое поддерживает приложения SpringBoot 1.5 и 2.0, но не имеет возможности тонких зависимостей встроенного сервера от приложений Spring Boot 2.1 ,С тех пор эта возможность была добавлена ​​в Liberty 19.0.0.2 .Пожалуйста, обновитесь до Liberty 19.0.0.2 и повторите ваш сценарий.И если обновление не решает проблему, я открыл open-liberty проблему 6870 для дальнейшего обсуждения и обнаружения.

...