【问题标题】:JDOFatalUserException: Illegal argument (on GAE J, but not on development system)JDOFatalUserException:非法参数(在 GAE J 上,但不在开发系统上)
【发布时间】:2012-11-22 22:53:29
【问题描述】:

我正在 Google App Engine/Java 上开发一个应用程序。 在我的开发环境中,应用程序运行良好,数据存储和检索成功。但是,在上传到应用程序引擎时,我不断收到错误“javax.jdo.JDOFatalUserException:非法参数”。从堆栈跟踪来看,这似乎发生在我调用 (List query.execute()).size() 时。 相关的堆栈跟踪是。

2012-11-22 23:34:08.512
[s~qalmadev1/1.363360558551053190].<stderr>: javax.jdo.JDOFatalUserException: Illegal argument

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at org.datanucleus.api.jdo.NucleusJDOHelper.getJDOExceptionForNucleusException(NucleusJDOHelper.java:488)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at org.datanucleus.api.jdo.JDOAdapter.getApiExceptionForNucleusException(JDOAdapter.java:1107)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at com.google.appengine.datanucleus.query.QueryExceptionWrappers$2.get(QueryExceptionWrappers.java:72)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at com.google.appengine.datanucleus.query.RuntimeExceptionWrappingIterator.hasNext(RuntimeExceptionWrappingIterator.java:103)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at com.google.appengine.datanucleus.query.LazyResult.resolveAll(LazyResult.java:120)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at com.google.appengine.datanucleus.query.LazyResult.size(LazyResult.java:115)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at com.google.appengine.datanucleus.query.StreamingQueryResult.size(StreamingQueryResult.java:151)

W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>:    at com.xxx.xxx.appengine.server.CreateEventServlet.doPost(CreateEventServlet.java:115)

我的 CreateEventServlet 中的第 115 行是下面代码中的“if()”行

Query query = pm.newQuery("select from com.xxx.xxx.appengine.User "
        + "where key == :userid");
        List<User> result = (List<User>) query.execute(userid);
        if (result != null && result.size() > 0) { // Line 115
            user = result.get(0);
            USER_VALID = true;
        }

【问题讨论】:

  • 您是否明确将您的实体名称设置为com.xxx.xxx.appengine.User?如果不只是在查询中使用select from User
  • 我个人会打印出嵌套异常,这是真正的异常,它会告诉您实际存在问题的行(在公开可见的开源插件代码中)

标签: java google-app-engine google-cloud-datastore jdo


【解决方案1】:

找到问题了。

Query query = pm.newQuery("select from com.xxx. xxx.appengine.User "
    + "where key == :userid");

在查询中,“userid”指的是通过KeyFactory.keyToString()实现的String。 使用 KeyFactory.stringToKey() 将字符串转换回密钥解决了这个问题。

【讨论】:

  • 您必须将此标记为已接受的答案。阅读here 如何做到这一点。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2014-06-26
  • 1970-01-01
  • 2011-02-01
  • 1970-01-01
  • 2011-02-16
  • 2011-04-08
  • 2011-06-19
相关资源
最近更新 更多