- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个关于在 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/
我是一名优秀的程序员,十分优秀!