Używam RoboSpice z Spring dla Androida i chciałbym utrzymywać tablicę obiektów JSON z OrmLite. GSON jest używany do zestawiania JSON. Przy domyślnym buforowaniu wszystko działa zgodnie z oczekiwaniami. Ale OrmLite nie lubi zestawu obiektów.RoboSpice utrzymuje tablicę JSON z OrmLite
Jest to uproszczona wersja JSON:
[{"id": 1, "title": "Test 1"},{"id": 2, "title": "Test 3"},{"id": 3, "title": "Test 3"}]
chciałbym utrzymywać to w następujący obiektu:
@DatabaseTable
public class Foo {
@DatabaseField(id = true)
private int id;
@DatabaseField
private String title;
// getters and setters
...
}
na przykładzie RoboSpice OrmLite Utworzyłem następujące GsonSpringAndroidSpiceService klasa, aby dodać OrmLite CacheManager. Tutaj zaczyna się problem.
public class CustomGsonSpringAndroidSpiceService extends GsonSpringAndroidSpiceService
{
@Override
public CacheManager createCacheManager(Application application)
{
// add persisted classes to class collection
List<Class<?>> classCollection = new ArrayList<Class<?>>();
classCollection.add(Foo.class);
// init
CacheManager cacheManager = new CacheManager();
cacheManager.addPersister(new InDatabaseObjectPersisterFactory(
application, new RoboSpiceDatabaseHelper(
application, "database.db", 1), classCollection));
return cacheManager;
}
}
Wynika to w następujący błąd:
RequestProcessor.java:174(22356): java.lang.RuntimeException: Class [Lcom.example.model.Foo; is not handled by any registered factoryList
Kiedy zmienić classCollection.add(Foo.class);
do classCollection.add(Foo[].class);
pojawia się następujący błąd:
RequestProcessor.java:174(22601): 14:42:23.112 pool-5-thread-1 An unexpected error occured when processsing request CachedSpiceRequest [requestCacheKey=foo, cacheDuration=-1, [email protected]]
RequestProcessor.java:174(22601): java.lang.IllegalArgumentException: No fields have a DatabaseField annotation in class [Lcom.example.app.model.Foo;
, ktoś pomysł jak obsługiwać tablicę JSON z OrmLite CacheManager?
Może być duplikatem http://stackoverflow.com/q/15801315/693752 – Snicolas
@Snicolas Nie chcę przedstawić dodatkowa klasa wyników, zobacz moją odpowiedź na temat obejścia tego problemu. – Uipko