java - 将二进制数据发布到 RESTEasy 服务时出现 NPE

标签 java jboss resteasy

我的环境是 JBOSS AS 5.1.0-GA、Struts 2.1.8 和 RESTEasy 1.2.GA

当发布到我的服务时,我在 Block getter 上收到一个 NPE,该 getter 是从 @Consumes 注释调用的。 我对它可能是什么感到有些茫然,任何帮助将不胜感激。

提前谢谢您。

乔诺

public class MyForm
{
    @FormParam("block")
    @PartType("application/octet-stream")
    private byte[] block;

    public MyForm(){}

    public byte[] getBlock()
    {
        return block;
    }

    public void setBlock(final byte[] block)
    {
        this.block =  block;
    }
}


@Path("/service")  
public class Service
{

    @Consumes("multipart/form-data")
    @POST
    public Response post(@MultipartForm MyForm form)
    {
        System.out.println(" recieved form " + form);
        ......
    }
}

异常

请注意,我删除了行号,因为它们与示例中的行号不对应。

java.lang.NullPointerException
    at MyForm.getBlock(MyForm.java:)
    at Service.postFileBlock(Service.java:)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.jboss.resteasy.core.MethodInjectorImpl.invoke(MethodInjectorImpl.java:119)
    at org.jboss.resteasy.core.ResourceMethod.invokeOnTarget(ResourceMethod.java:211)
    at org.jboss.resteasy.core.ResourceMethod.invoke(ResourceMethod.java:176)
    at org.jboss.resteasy.core.ResourceMethod.invoke(ResourceMethod.java:166)
    at org.jboss.resteasy.core.SynchronousDispatcher.getResponse(SynchronousDispatcher.java:359)
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:336)
    at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:103)
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:114)
    at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.struts2.dispatcher.ng.filter.StrutsExecuteFilter.doFilter(StrutsExecuteFilter.java:67)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at com.opensymphony.sitemesh.webapp.SiteMeshFilter.obtainContent(SiteMeshFilter.java:129)
    at com.opensymphony.sitemesh.webapp.SiteMeshFilter.doFilter(SiteMeshFilter.java:77)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareFilter.doFilter(StrutsPrepareFilter.java:82)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:235)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:190)
    at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:92)
    at org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.process(SecurityContextEstablishmentValve.java:126)
    at org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.invoke(SecurityContextEstablishmentValve.java:70)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:158)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:330)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:829)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:598)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
    at java.lang.Thread.run(Thread.java:637)

请注意:这是来自 Resteasy 开发者邮件列表的交叉帖子。

最佳答案

二进制数据是一个转移注意力的东西,我将注释放在了错误的位置,它们应该位于 setter 方法而不是成员变量上。

public class MyForm
{
   private byte[] block;

   public MyForm(){}

   public byte[] getBlock()
   {
       return block;
   }

   @FormParam("block")
   @PartType("application/octet-stream")
   public void setBlock(final byte[] block)
   {
       this.block =  block;
   }
}

关于java - 将二进制数据发布到 RESTEasy 服务时出现 NPE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1873001/

相关文章:

java - 当我使用命令 `mvn test -Xlint:unchecked` 时。出现一些错误

java - 获取字符串中特定单词之后的字符?

java - 检查数组是否已满

java - 带有消费者代码的执行器服务框架

java - 我如何在 JBoss eap 6.1 服务器中启用 XSLT 2.0 处理器,以消除 XSLT 2.0 函数不可用等错误

java - 通过keycloak管理客户端在keycloak中创建用户返回IllegalArgumentException

java - JBoss Developer Studio 与 MySQL 的集成问题

java - HTTP Resteasy 客户端 SSL 信任所有证书

java - 如何使 RESTful 服务处理响应中的自定义对象?

java - ServletServerCache 和 ClassNotFoundException 之谜