【问题标题】:Content Provider not working on Nexus family devices内容提供程序无法在 Nexus 系列设备上运行
【发布时间】:2012-08-02 09:04:47
【问题描述】:

我正在开发一个带有 ContentProvider 的应用程序来提供一些内部文件(二进制文件)。当我将它部署在三星 Galaxy S、SII 或任何其他设备上时,它运行良好,当我在 Galaxy Nexus 或 Nexus S 上试用时购买,它不起作用!

场景:

可以使用两个 URI 访问我的 ContentProvider。根据此 URI,提供者创建 DataCursor(扩展 CrossProcessCursor)或 ModelCursor(也扩展 CrossProcessCursos)。事实是,在 Nexus 系列中,我访问第一个游标 (DataCursor) 以检索标识符,它运行良好,但是在访问第二个游标时,尝试时总是抛出“OutOfBoundsException”

getBlob()

方法。

提供者

@Override
    public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
        Cursor cursor = null;

        // If the third app requieres DATA (phrase id, phrase string and phrase name)
        if(uri.toString().equalsIgnoreCase(ProviderConstants.DATA_URI.toString())) {
            // Build the DataHelper and the customized cursor
            DataHelper dataHelper = new DataHelper(getContext());
            cursor = new DataCursor(dataHelper);
        } else if(uri.toString().equalsIgnoreCase(ProviderConstants.MODEL_URI.toString())) {            
            // Let's take the model id from the selectionArgs...
            if (selectionArgs != null && selectionArgs.length > 0) {
                String modelId = selectionArgs[0];

                // Get an instance to the persistent storage service...
                File file = FileManager.getDirectory(getContext(), modelId);
                FileSystemPersistentStorageService clientPersistentStorageService = new FileSystemPersistentStorageService(file);

                cursor = new ModelCursor(clientPersistentStorageService);
            } else {
                Log.e("ContentProvider", "Query without model id on selectionArgs");
            }
        }

        return cursor;
    }

如果您需要一些代码或任何东西,请尽管索取!

非常感谢。

【问题讨论】:

  • 对于初学者:1. 您的 Android 设备上有哪些确切的 SDK 版本? 2. 每个设备上的确切 SQLite 版本是什么 (adb shell sqlite3 --version) 3. 代码在模拟器中是否正常工作? 4. 当您得到 OutOfBoundsException 时,完整的调用堆栈是什么? 5. ModelCursor 是如何实现的? 6. 你的数据库模型是什么? 7. 你如何使用你的内容提供者(代码)?
  • 1.从 2.3.3 到 4.0(广泛的设备) 2. 重要吗?我可以检查它们,但 ModelCursor 不会从 SQLite 中获取数据,而只是从内部文件 storage.3 中获取数据。 [待测试,谢谢]。 4.link。 5. 只需要getBlob,其他需要link。 6.不需要数据库。 7.Cursor modelCursor = getContentResolver().query(Uri.parse("content://" + PROVIDER_NAME + "/model"), null, null, new String[] {modelId}, null);-modelCursor.getBlob(0);
  • 您是否尝试将光标移动到第一个条目? (modelCursor.moveToFirst())

标签: android android-contentprovider google-nexus


【解决方案1】:

我终于得到了答案。这不是设备的原因,而是 Android 操作系统版本的原因。

从 4.0.3 开始的早期版本以一种方式实现了 AbstarctCursor 的 fillWindow() 方法,不需要将第一项的光标位置设置为 0。 4.0.3(as seen here)之后,修改了这个方法,导致没有设置光标位置为0。

抛出的异常是:

07-31 11:35:09.938: W/System.err(2760): android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1
07-31 11:35:09.985: W/System.err(2760):     at android.database.AbstractCursor.checkPosition(AbstractCursor.java:418)
07-31 11:35:09.989: W/System.err(2760):     at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
07-31 11:35:09.989: W/System.err(2760):     at android.database.AbstractWindowedCursor.getBlob(AbstractWindowedCursor.java:44)
07-31 11:35:09.993: W/System.err(2760):     at android.database.CursorWrapper.getBlob(CursorWrapper.java:122)
07-31 11:35:09.993: W/System.err(2760):     at es.agnitio.kivox.mobile.internal.ModelImporterAndroidImpl.importModelPackage(ModelImporterAndroidImpl.java:44)
07-31 11:35:09.993: W/System.err(2760):     at es.agnitio.kivox.mobile.internal.KivoxMobileBasicCode.importModel(KivoxMobileBasicCode.java:159)
07-31 11:35:09.997: W/System.err(2760):     at es.agnitio.kivox.mobile.internal.KivoxMobileBasicImpl.importModel(KivoxMobileBasicImpl.java:47)
07-31 11:35:09.997: W/System.err(2760):     at es.agnitio.kivoxmobile.testing.KivoxMobileBasicTrial.onCreate(KivoxMobileBasicTrial.java:63)
07-31 11:35:09.997: W/System.err(2760):     at android.app.Activity.performCreate(Activity.java:5008)
07-31 11:35:10.001: W/System.err(2760):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
07-31 11:35:10.001: W/System.err(2760):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
07-31 11:35:10.001: W/System.err(2760):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
07-31 11:35:10.004: W/System.err(2760):     at android.app.ActivityThread.access$600(ActivityThread.java:130)
07-31 11:35:10.004: W/System.err(2760):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
07-31 11:35:10.004: W/System.err(2760):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-31 11:35:10.008: W/System.err(2760):     at android.os.Looper.loop(Looper.java:137)
07-31 11:35:10.008: W/System.err(2760):     at android.app.ActivityThread.main(ActivityThread.java:4745)
07-31 11:35:10.008: W/System.err(2760):     at java.lang.reflect.Method.invokeNative(Native Method)
07-31 11:35:10.012: W/System.err(2760):     at java.lang.reflect.Method.invoke(Method.java:511)
07-31 11:35:10.012: W/System.err(2760):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-31 11:35:10.012: W/System.err(2760):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
07-31 11:35:10.016: W/System.err(2760):     at dalvik.system.NativeStart.main(Native Method)

这表明(经过深入研究),光标索引未设置在 fillWindow() 上。

解决方案

要解决这个“碎片化”问题,只需在自定义光标的moveToFirst()move()(带有一些应用程序逻辑)等方法中添加moveToPosition(0)。这将使游标索引设置为0,避免“-1”索引请求异常。

希望对大家有帮助 =)

【讨论】:

    【解决方案2】:

    这个我有点需要水晶球,但是……你可以尝试两件事:

    • 按照SteveR 的建议,将光标移至第一个条目。

    • 其次,我在使用 Dell Streak 7" 平板电脑时遇到了类似的问题。据说它是设备列表的一部分,但在访问其内部存储方面有一个特殊例外。很难找到,但使用 if 语句进行排序。它可能是类似的,尽管我对此表示怀疑,特别是因为 Nexus 应该是开发人员的设备。

    也许您应该尝试运行最简单的 ContentProvider 测试应用程序,看看它在这些设备上的表现如何。

    【讨论】:

    • 很抱歉回答迟了。我已经测试了所有这些。关键是moveToFirst() 返回false。就像系统无法找到提供者一样,很奇怪,因为在其他设备中它找到了它。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2011-09-28
    • 2017-03-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-07-17
    相关资源
    最近更新 更多