Android,Glide Image Loading Library:NullPointerException,ProviderInfo

时间:2017-01-19 23:02:38

标签: java android nullpointerexception android-glide

刚进入Android的Glide图片加载库。目前正在使用此处的一些代码: https://github.com/bumptech/glide/issues/459

我的完整项目就是你想看看它:

https://github.com/mhurwicz/glide02

当我在Android Studio中的模拟器中运行应用程序时,我收到以下异常:

java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.XmlResourceParser android.content.pm.ProviderInfo.loadXmlMetaData(android.content.pm.PackageManager, java.lang.String)' on a null object reference

这是MainActivity中的关键声明:

new ShareTask(this).execute("http://thelink");

thelink实际上是goo.gl/gEgYUd - 无法将其留在上面,因为stackoverflow不允许使用URL缩短器。)

这是我的ShareTask类的代码

class ShareTask extends AsyncTask<String, Void, File> {
    private final Context context;

    public ShareTask(Context context) {
        this.context = context;
    }
    @Override protected File doInBackground(String... params) {
        String url = params[0]; // should be easy to extend to share multiple images at once
        try {
            return Glide
                    .with(context)
                    .load(url)
                    .downloadOnly(Target.SIZE_ORIGINAL, Target.SIZE_ORIGINAL)
                    .get() // needs to be called on background thread
                    ;
        } catch (Exception ex) {
            Log.w("SHARE", "Sharing " + url + " failed", ex);
            return null;
        }
    }
    @Override protected void onPostExecute(File result) {
        if (result == null) { return; }
        Uri uri = FileProvider.getUriForFile(context, context.getPackageName(), result);
        share(uri); // startActivity probably needs UI thread
    }

    private void share(Uri result) {
        Intent intent = new Intent(Intent.ACTION_SEND);
        intent.setType("image/jpeg");
        intent.putExtra(Intent.EXTRA_SUBJECT, "Shared image");
        intent.putExtra(Intent.EXTRA_TEXT, "Look what I found!");
        intent.putExtra(Intent.EXTRA_STREAM, result);
        context.startActivity(Intent.createChooser(intent, "Share image"));
    }
}

使用调试,似乎我可能在get()语句中遇到麻烦。首先,宽度和高度是非常大的负数。 (请参阅下面以绿色突出显示的代码。)然后get()语句返回null。 (参见下面红色突出显示的代码。)

提前感谢您提供的任何帮助!

enter image description here

1 个答案:

答案 0 :(得分:2)

NPE来自FileProvider.getUriForFile,因为您传递的是错误的权限。您在清单中声明了android:authorities="com.example.fileprovider",但您在通话时使用了套餐名称。这无法解决info中的FileProvider.parsePathStrategy。匹配这两个字符串,你就可以了。

最简单的解决方法是使用android:authorities="${applicationId}",这会导致0个硬编码字符串,因此您可以继续使用context.getPackageName()

关于调试过程中的问题:

  • Target.SIZE_ORIGINAL被声明为MIN_VALUE,因此大数
  • 它没有返回null,IDEA只是对方法中的位置感到困惑,return null;如果在{{1}中失败则不应该执行} code。
  • FileProviderdoGet(null)是超时,在代码中正确防范

我已经运行了应用程序,奇怪的是我有一个日志行说

  

W / SHARE:分享http:// ...失败

但不是堆栈跟踪,这很奇怪,因为null中的ex不能是null