gpt4 book ai didi

android - 如何在 Android SyncAdapter 中使用 GWT-RequestFactory(总是出现 ValidationTool-Error)

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:06:36 25 4
gpt4 key购买 nike

我有一个关于在 Android 中使用 GWT-RequestFactory 的问题。作为起点,我使用了“创建 AppEngine 连接的 Android 项目”向导中的代码(信息:http://code.google.com/intl/de-DE/eclipse/docs/appengine_connected_android.html)并且效果很好。

但现在在我的例子中,我想扩展此应用程序以使用带有 SQLite 的本地 ContentProvider 和带有 SyncAdapter 的 SyncService 使用 RequestFactory 将数据从 ContentProvider 同步到 AppEngine。现在我的问题如下:我可以调用

MyRequestFactory requestFactory = Util.getRequestFactory(mContext, MyRequestFactory.class);

在我想要的任何 Activity 中都会收到 MyRequestFactory 的实例。 (注意:Util 是由向导创建的类。)但是如果我尝试从我的 SyncAdapter 进行相同的调用,我将得到一个 java.lang.RuntimeException:必须为 com.hotool.client.MyRequestFactory RequestFactory 类型运行 RequestFactory ValidationTool。

也许供您引用:Util.getRequestFacory 方法如下所示:

/**
* Creates and returns an initialized {@link RequestFactory} of the given
* type.
*/
public static <T extends RequestFactory> T getRequestFactory(
Context context, Class<T> factoryClass) {

T requestFactory = RequestFactorySource.create(factoryClass);

SharedPreferences prefs = getSharedPreferences(context);
String authCookie = prefs.getString(Util.AUTH_COOKIE, null);

String uriString = Util.getBaseUrl(context) + RF_METHOD;
URI uri;
try {
uri = new URI(uriString);
} catch (URISyntaxException e) {
Log.w(TAG, "Bad URI: " + uriString, e);
return null;
}
requestFactory.initialize(new SimpleEventBus(),
new AndroidRequestTransport(uri, authCookie));

return requestFactory;
}

错误发生在RequestFactorySource,它位于requestfactory-client.jar我认为,这可能是一个类加载器问题,但没有成功。

我尝试使用 ValidationTool 但首先它没有帮助,其次我发现 ValidationTool 将生成的类已经就位(可能要感谢此处提到的注释处理:http://code.google.com/p/google-web-toolkit/wiki/RequestFactoryInterfaceValidation)

有人知道是什么原因造成的吗?

非常感谢和最好的问候。

马库斯·纽恩施万德

最佳答案

你是对的,马克,这是一个类加载器问题。

它发生在 requestfactory-client.jar 中,这里是相关来源:

class InProcessRequestFactory extends AbstractRequestFactory {

//...

public InProcessRequestFactory(Class<? extends RequestFactory> requestFactoryInterface) {
this.requestFactoryInterface = requestFactoryInterface;
deobfuscator =
Deobfuscator.Builder.load(requestFactoryInterface,
Thread.currentThread().getContextClassLoader()).build();
}

//...

}

public class Deobfuscator {

//...

public static class Builder {
public static Builder load(Class<?> clazz, ClassLoader resolveClassesWith) {
Throwable ex;
try {
Class<?> found;
try {
// Used by the server
found = Class.forName(clazz.getName() + GENERATED_SUFFIX, false, resolveClassesWith);
} catch (ClassNotFoundException ignored) {
// Used by JRE-only clients
found = Class.forName(clazz.getName() + GENERATED_SUFFIX_LITE, false, resolveClassesWith);
}
Class<? extends Builder> builderClass = found.asSubclass(Builder.class);
Builder builder = builderClass.newInstance();
return builder;
} catch (ClassNotFoundException e) {
throw new RuntimeException("The RequestFactory ValidationTool must be run for the "
+ clazz.getCanonicalName() + " RequestFactory type");
} catch (InstantiationException e) {
ex = e;
} catch (IllegalAccessException e) {
ex = e;
}
throw new RuntimeException(ex);
}

//...

}

问题是当从 Android 上的同步适配器调用 Thread.currentThread().getContextClassLoader() 时似乎返回空值,因为同步适配器线程是由系统创建的,而不是由您的应用程序创建的。

我通过在创建 requestfactory 实例之前在 onPerformSync 方法中手动调用 setContextClassLoader 解决了这个问题:

@Override
public void onPerformSync(final Account account, Bundle extras,
String authority, final ContentProviderClient provider,
final SyncResult syncResult) {

Thread.currentThread().setContextClassLoader(mContext.getClassLoader());

// ...

MyRequestFactory requestFactory = Util.getRequestFactory(mContext,
MyRequestFactory.class, acsidToken);

// ...
}

我希望这是有道理的。安德烈亚斯

关于android - 如何在 Android SyncAdapter 中使用 GWT-RequestFactory(总是出现 ValidationTool-Error),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8049351/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com