0

我正在使用Google Data API从 Android 连接 Picasa。要检索图片和元数据,它工作得很好,但我在解析 PATCH 的响应(相对于原始)时收到 IllegalArgumentException。标题是“text/html”,尽管 parseAsString 方法的输出提供了一个完美的 xml 字符串。这是一个错误还是我需要为“text/html”创建自己的解析器?

我也不介意用 PUT 方法更新,有没有人有一个很好的例子如何用 Java 做到这一点?

这里例外:

Uncaught handler: thread main exiting due to uncaught exception
 java.lang.IllegalArgumentException: No parser defined for Content-Type: text/html; charset=UTF-8
 at com.google.api.client.http.HttpResponse.parseAs(HttpResponse.java:277)
 at com.unimelb.pt3.external.google.api.Entry.executePatchRelativeToOriginal(Entry.java:95)
 at com.unimelb.pt3.external.google.api.PhotoEntry.executePatchRelativeToOriginal(PhotoEntry.java:67)
 at com.unimelb.pt3.Picasa.updatePicture(Picasa.java:135)
 at com.unimelb.pt3.Tools.updatePictureOnPicasa(Tools.java:209)
 at com.unimelb.pt3.ui.WaterfallView.onDraw(WaterfallView.java:145)
 at android.view.View.draw(View.java:6535)
 at android.view.ViewGroup.drawChild(ViewGroup.java:1531)
 at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
 at android.view.ViewGroup.drawChild(ViewGroup.java:1529)
 at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
 at android.view.View.draw(View.java:6538)
 at android.widget.FrameLayout.draw(FrameLayout.java:352)
 at android.view.ViewGroup.drawChild(ViewGroup.java:1531)
 at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
 at android.view.ViewGroup.drawChild(ViewGroup.java:1529)
 at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
 at android.view.View.draw(View.java:6538)
 at android.widget.FrameLayout.draw(FrameLayout.java:352)
 at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1830)
 at android.view.ViewRoot.draw(ViewRoot.java:1349)
 at android.view.ViewRoot.performTraversals(ViewRoot.java:1114)
 at android.view.ViewRoot.handleMessage(ViewRoot.java:1633)
 at android.os.Handler.dispatchMessage(Handler.java:99)
 at android.os.Looper.loop(Looper.java:123)
 at android.app.ActivityThread.main(ActivityThread.java:4363)
 at java.lang.reflect.Method.invokeNative(Native Method)
 at java.lang.reflect.Method.invoke(Method.java:521)
 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
 at dalvik.system.NativeStart.main(Native Method)

这里是条目中的代码:

Entry executePatchRelativeToOriginal(HttpTransport transport, Entry original)
  throws IOException {
      HttpRequest request = transport.buildPatchRequest();
      request.setUrl(getEditLink());
      request.headers.ifMatch = etag;
      AtomPatchRelativeToOriginalContent content =
          new AtomPatchRelativeToOriginalContent();
      content.namespaceDictionary = Util.NAMESPACE_DICTIONARY;
      content.originalEntry = original;
      content.patchedEntry = this;
      request.content = content;
      Log.i(Prototype.TAG, request.url.toString());
      HttpResponse response = request.execute();
      // Log.i(Prototype.TAG, response.parseAsString());
      return response.parseAs(getClass());
}

这里是主要活动的相关代码:

public void updatePicture(String url, String description, String[] tags) throws IOException {
    PhotoEntry photo = photos.get(url);
    PhotoEntry patched = photo.clone();
    patched.summary = description;
    String keywords = "";
    for(int i=0; i<tags.length; i++) {
        keywords += tags[i] + ((i==tags.length-1) ? "" : ", ");
    }
    patched.mediaGroup.keywords = keywords;
    photo = patched.executePatchRelativeToOriginal(transport, photo);
}

private HttpTransport setUpTransport() {
    HttpTransport transport = GoogleTransport.create();
    GoogleHeaders headers = (GoogleHeaders) transport.defaultHeaders;
    headers.setApplicationName("google-picasaatomsample-1.0");
    headers.gdataVersion = "2";
    AtomParser parser = new AtomParser();
    parser.namespaceDictionary = Util.NAMESPACE_DICTIONARY;
    transport.addParser(parser);
    return transport;
}

编辑: 我在 setUpTransport 方法中添加了以下几行:

   XmlHttpParser p2 = new XmlHttpParser();
   p2.contentType = "text/html";
   p2.namespaceDictionary = Util.NAMESPACE_DICTIONARY;
   transport.addParser(p2); 

这会导致另一个带有该日志的 IllegalArgumentException:

 Uncaught handler: thread main exiting due to uncaught exception
 java.lang.IllegalArgumentException: expected start of XML element, but got something else (event type 4)
     at com.google.api.client.xml.Xml.parseElementInternal(Xml.java:180)
     at com.google.api.client.xml.Xml.parseElement(Xml.java:152)
     at com.google.api.client.xml.XmlHttpParser.parse(XmlHttpParser.java:73)
     at com.google.api.client.http.HttpResponse.parseAs(HttpResponse.java:280)
     at com.unimelb.pt3.external.google.api.Entry.executePatchRelativeToOriginal(Entry.java:95)
     at com.unimelb.pt3.external.google.api.PhotoEntry.executePatchRelativeToOriginal(PhotoEntry.java:67)
     at com.unimelb.pt3.Picasa.updatePicture(Picasa.java:130)
     at com.unimelb.pt3.Tools.updatePictureOnPicasa(Tools.java:209)
     at com.unimelb.pt3.ui.WaterfallView.onDraw(WaterfallView.java:145)
     at android.view.View.draw(View.java:6535)
     at android.view.ViewGroup.drawChild(ViewGroup.java:1531)
     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:158)
     at android.view.ViewGroup.drawChild(ViewGroup.java:1529)
     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
     at android.view.View.draw(View.java:6538)
     at android.widget.FrameLayout.draw(FrameLayout.java:352)
     at android.view.ViewGroup.drawChild(ViewGroup.java:1531)
     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
     at android.view.ViewGroup.drawChild(ViewGroup.java:1529)
     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1258)
     at android.view.View.draw(View.java:6538)
     at android.widget.FrameLayout.draw(FrameLayout.java:352)
     at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1830)
     at android.view.ViewRoot.draw(ViewRoot.java:1349)
     at android.view.ViewRoot.performTraversals(ViewRoot.java:1114)
     at android.view.ViewRoot.handleMessage(ViewRoot.java:1633)
     at android.os.Handler.dispatchMessage(Handler.java:99)
     at android.os.Looper.loop(Looper.java:123)
     at android.app.ActivityThread.main(ActivityThread.java:4363)
     at java.lang.reflect.Method.invokeNative(Native Method)
     at java.lang.reflect.Method.invoke(Method.java:521)
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
     at dalvik.system.NativeStart.main(Native Method)
4

1 回答 1

1

尝试使用XmlHttpParser并将其内容类型设置为“text/html”。

顺便说一句,为了响应 PATCH,Picasa Data API 应该返回内容类型“application/xml”,而不是“text/html”。所以这可能是一个错误。

编辑:我自己没有对此进行调查,但我怀疑这个 IllegalArgumentException 是因为 text/html 内容不是格式正确的 XML 内容。我们实际上没有 HTML 解析器。我想知道为什么你觉得你需要解析 HTML 响应,因为 parseAsString 给了你你需要的东西。顺便说一句,Picasa Data API 不应该返回 HTML 响应,所以这可能是他们的一个错误(不是说除了提交错误报告之外您可以做任何事情)。

免责声明:我是google-api-java-client项目的所有者。

于 2010-12-11T15:22:49.607 回答