0

これが私がやろうとしていることです.RESTEasyのドキュメントについて何かが欠けているようです.助けてくれてありがとう.

私のチームは、REST 公開サービス (排他的に JSON) に常に200 (ok) ステータスを返すことにしました。そのため、RESTEasy フレームワークが提供する Exception Mapper メカニズムに依存することにしました。

つまり、コード内の特定の (ビジネス上または技術上の) 問題に対して Special RuntimeException を発生させ、マッパーは ErrorBean を Response Body として構築する必要があります。

これを行うためのコードの最も重要な部分は次のとおりです。

特別な例外を発生させるリソース メソッド:

    @GET
@Produces({ MediaType.APPLICATION_JSON })
@BadgerFish
@ApiOperation(value = "gets all documents of the current user", notes = "gets all documents of the current user", responseClass = "com.cdc.pcp.api.bean.DocumentVO", multiValueResponse=true)
public Response getAllDocuments() throws PCPResourceException {

    try {
        UserInformation userInformation = userService.getUserInformation(getUsername());
        List<ParapheurNodeInformation> nodesInformations = new ArrayList<ParapheurNodeInformation>();
        nodesInformations = taskService.getTasksReadyToSignOrValidate(userInformation);
        int i = 0/0;
        return Response.ok(BeanConverter.toDocumentVOList(nodesInformations)).build();
    } catch (Exception e) {
        LOG.error("Erreur lors de la récupération de la liste des documents pour l'utilisateur : " + getUsername() , e);

        throw new PCPResourceException(e.getMessage(), "Erreur lors de la récupération de la liste des documents pour l'utilisateur", ResourceErrorCode.INTERNAL_ERROR, e);         
    }
}

特別な例外マッパー:

@Provider
public class PCPResourceExceptionMapper implements ExceptionMapper<PCPResourceException> {

@Override
public Response toResponse(PCPResourceException exception) {
    ErrorBean eb =new ErrorBean();
    eb.setDeveloperMessage("lol");
    eb.setErrorCode(0);
    eb.setGeneration(new Date());
    eb.setGravity(Gravity.ERROR);
    eb.setMoreInfoUrl("lolll");
    eb.setUserFriendlyMessage("fuck");
    GenericEntity<ErrorBean> e = new GenericEntity<ErrorBean>(eb) {
    };
    return Response.ok(e).build();
}

}

ログ

org.jboss.resteasy.spi.UnhandledException: org.jboss.resteasy.spi.WriterException: java.lang.NullPointerException
org.jboss.resteasy.core.SynchronousDispatcher.writeFailure(SynchronousDispatcher.java:460)
org.jboss.resteasy.core.SynchronousDispatcher.executeExceptionMapper(SynchronousDispatcher.java:349)
org.jboss.resteasy.core.SynchronousDispatcher.unwrapException(SynchronousDispatcher.java:373)
org.jboss.resteasy.core.SynchronousDispatcher.handleApplicationException(SynchronousDispatcher.java:362)
org.jboss.resteasy.core.SynchronousDispatcher.handleException(SynchronousDispatcher.java:233)
org.jboss.resteasy.core.SynchronousDispatcher.handleInvokerException(SynchronousDispatcher.java:209)
org.jboss.resteasy.core.SynchronousDispatcher.getResponse(SynchronousDispatcher.java:557)
org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:524)
org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:126)
org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:208)
org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:55)
org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:50)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
com.cdc.pcp.api.util.ApiOriginFilter.doFilter(ApiOriginFilter.java:32)
4

2 に答える 2

0

それは答えではありませんが、それは始まりです。この行: org.jboss.resteasy.core.SynchronousDispatcher.writeFailure(SynchronousDispatcher.java:460) here: SynchronousDispatcherを見たとき、その時点で null になる可能性があるのは: だけだと推測できましたResteasyProviderFactory

依存関係が不足しているか、このプロバイダー ファクトリを登録していないと思います。

ExceptionMappers は MessageBodyReaders および MessageBodyWriters と同じ方法で登録されます: RESTEasy プロバイダーの context-param (WAR ファイルにデプロイする場合) をスキャンするか、プログラムで ResteasyProviderFactory クラスを介して登録します。から:

于 2013-05-24T11:41:45.623 に答える