【问题标题】:DWR - Broken reflection Exception in Jetty 9DWR - Jetty 9 中的破碎反射异常
【发布时间】:2014-09-26 21:58:06
【问题描述】:

我们目前正在开发一个使用部署到 Tomcat 的 DWR 3.0.RC2 的应用程序,其中 DWR 已配置并按预期工作。我们正在考虑改用 Jetty,我正在处理迁移过程。但是,我在服务器上遇到了导致 DWR 无法工作的异常,我想知道是否有人遇到过这个问题或有任何建议(以防我错过了一些配置等。

应用程序加载并启动。浏览到时,我们在浏览器控制台中收到错误,并且 DWR 数据未按预期推送。服务器日志显示每个请求期间使用 DWR 推送的堆栈跟踪。

当前部署(工作)在 Tomcat 7.0.21 上,我们正在尝试迁移到 Jetty 9.2.3.v20140905(不工作)。有人可以提供一些指针吗?

码头配置:

100% 默认(新下载用于此用途),运行 java -jar start.jar --add-to-startd=https 以启用 HTTPS 除外。

相关web.xml配置:

<servlet>
  <description>Direct Web Remoting Servlet</description>
  <display-name>DWR Servlet</display-name>
  <servlet-name>dwr-invoker</servlet-name>
  <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>

  <!-- We're currently using Java annotations instead of a separate dwr.xml 
       config file. -->
  <init-param>
      <!-- The "classes" servlet parameter must provide a comma-separated 
           list of the fully-qualified class names of all annotated classes 
           to be used with DWR. -->
      <param-name>classes</param-name>
      <param-value>
          org.ourdomain.ourapp.ApplicationDWR, 
          org.ourdomain.ourapp.DataImportDWR
      </param-value>
  </init-param>

    <!-- Remove this unless you want to use active reverse ajax -->
    <init-param>
      <param-name>activeReverseAjaxEnabled</param-name>
      <param-value>true</param-value>
    </init-param>

    <!-- By default DWR creates application scope objects when they are first
    used. This creates them when the app-server is started -->
    <init-param>
      <param-name>initApplicationScopeCreatorsAtStartup</param-name>
      <param-value>true</param-value>
    </init-param>

    <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>dwr-invoker</servlet-name>
    <url-pattern>/dwr/*</url-pattern>
  </servlet-mapping>

错误:

客户:

Error: Object {name: "dwr.engine.missingData", message: "No data received from server"}

服务器:

13:12:09,621 ERROR JettyContinuationSleeper:181 - Broken reflection
java.lang.NullPointerException
        at org.directwebremoting.util.Continuation.resume(Continuation.java:107)
        at org.directwebremoting.server.jetty.JettyContinuationSleeper.wakeUp(JettyContinuationSleeper.java:177)
        at org.directwebremoting.impl.TimedAlarm$1.run(TimedAlarm.java:46)
        at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source)
        at java.util.concurrent.FutureTask.run(Unknown Source)
        at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(Unknown Source)
        at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(Unknown Source)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
        at java.lang.Thread.run(Unknown Source)

【问题讨论】:

    标签: java tomcat jetty dwr


    【解决方案1】:

    看起来 DWR 没有更新他们的support for Jetty since 7.0.1(这是 5 年前的)。

    似乎有一个Servlet3 support option,你可以使用/配置它吗? (Jetty 9 是一个有效的 Servlet 3.1 容器)

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2015-02-19
      • 1970-01-01
      • 1970-01-01
      • 2018-04-15
      • 2016-07-22
      • 1970-01-01
      • 2015-11-08
      相关资源
      最近更新 更多