Не удалось найти метаданные для провайдера с полномочиями
Я интегрировал Creative Kit от Snapchat в мое приложение для Android. После обработки я получаю изображение с сервера в виде массива байтов, который я сохраняю на диск, а затем отправляю файл в Creative Kit Snapchat, как показано ниже.
private fun downloadImage(
fileName: String,
imageByteArray: ByteArray?): Uri? {
val state = Environment.getExternalStorageState()
if (Environment.MEDIA_MOUNTED == state) {
val downloadDir = File(
Environment.getExternalStorageDirectory(), context?.getString(R.string.app_name)
)
if (!downloadDir.isDirectory) {
downloadDir.mkdirs()
}
val file = File(downloadDir, fileName)
var ostream: FileOutputStream? = null
try {
ostream = FileOutputStream(file)
ostream.write(imageByteArray)
ostream.flush()
ostream.close()
}
} catch (e: IOException) {
e.printStackTrace()
}
val snapCreativeKitApi = SnapCreative.getApi(context!!)
val snapMediaFactory = SnapCreative.getMediaFactory(context!!)
lateinit var snapPhotoFile: SnapPhotoFile
try {
snapPhotoFile = snapMediaFactory.getSnapPhotoFromFile(file)
} catch (e: SnapMediaSizeException) {
return
}
val snapPhotoContent = SnapPhotoContent(snapPhotoFile)
snapCreativeKitApi.send(snapPhotoContent)
}
}
Я также добавил provider
в файле манифеста, как показано ниже:
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.provider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths_app" />
</provider>
И в provider_paths_app.xml
, Я перепробовал все возможные пути, ссылаясь на этот ответ, и ни один из них не работает.
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-path
name="My App Name"
path="." />
</paths>
С вышеупомянутым путем я получаю ошибку ниже.
Couldn't find meta-data for provider with authority my.package.name.fileprovider
Все, что мне нужно сделать, это отправить это изображение в Snapchat, но я не могу понять, что я делаю неправильно. Любая помощь будет оценена.
19 ответов
Сначала напишите следующий тег в манифесте под тегом
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.provider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths" />
</provider>
Затем создайте папку xml в res и создайте имена файлов: укажите +paths.xml, а затем скопируйте и вставьте код:
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-path
name="external_files"
path="." />
</paths>
и теперь самая большая ошибка разработчика в программах для создания файла в программе, тогда мы будем использовать:
FileProvider.getUriForFile(Objects.requireNonNull(getApplicationContext()),
BuildConfig.APPLICATION_ID + ".provider", file);
Надеюсь, это сработает для тебя!!!
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths"></meta-data>
</provider>
Это моя декларация провайдера, значение ${application} равно "com.limxtop.research", убедитесь, что название полномочий совпадает с названием приведенных ниже кодов.
// Create the file where the photo should save.
File file = null;
try {
file = createImageFile();
} catch (IOException e) {
break;
}
// The second parameter is the name of authorities.
Uri uri = FileProvider.getUriForFile(this,
"com.limxtop.research.fileprovider", file);
intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION
| Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
startActivityForResult(intent, fullSizeRequestCode);
Так что, возможно, ваш пост с кодами здесь не завершен, вы должны передать my.package.name.fileprovider в качестве параметра some where.
В моем случае.
У меня есть проект библиотеки. Назовем его:LibApk.
Когда я кодирую это: applicationId "my.package.name" в build.grale(приложение)
при сборке gradle скажите мне, что: проекты библиотеки не могут устанавливать applicationId. applicationId в конфигурации по умолчанию установлено значение com.darcy.apkupdate.
Итак, я удаляю applicationId "my.package.name".
Тогда build.gradle будет выглядеть так:
Но я забыл обновить файл AndroidManifest.xml, который использует ${applicationId}
Это проблема!!!
Поэтому я изменил переменную на постоянную. Результат выглядит как на картинке ниже:
После этого для меня это работа!
Надеюсь, это поможет вам...
Если суффикс сборки другой, имеет смысл внести подобное изменение.
FileProvider.getUriForFile(mContext.get(), BuildConfig.APPLICATION_ID + ".fileprovider", file)
Проблема здесь в том, что вы используете имя класса .provider для полномочий в манифесте и используете имя класса .fileprovider в java-коде.
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.provider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths_app" />
</provider>
Couldn't find meta-data for provider with authority my.package.name.fileprovider
Просто переименуйте fileprovider в provider
В моем случае;
Файл манифеста:
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.provider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths" />
</provider>
Код:
import androidx.multidex.BuildConfig // NOT DO THIS!!!
val uri = FileProvider.getUriForFile(this,
BuildConfig.APPLICATION_ID+ ".provider", _tempFile)
Исключение:
java.lang.IllegalArgumentException: Couldn't find meta-data for provider with authority androidx.multidex.provider
Не используйте androidx.multidex.BuildConfig, потому что эти значения не являются значениями нашего приложения:
//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by Fernflower decompiler)
//
package androidx.multidex;
public final class BuildConfig {
public static final boolean DEBUG = false;
public static final String APPLICATION_ID = "androidx.multidex";
public static final String BUILD_TYPE = "release";
public static final String FLAVOR = "";
public static final int VERSION_CODE = -1;
public static final String VERSION_NAME = "";
public BuildConfig() {
}
}
FileProvider.getUriForFile(this, "{yourPAckageName}.fileprovider",
file);
к
FileProvider.getUriForFile(Objects.requireNonNull(getApplicationContext()),
BuildConfig.APPLICATION_ID + ".provider", file);
Я потратил день на поиски решения. Эта часть очень важна. Это спасло мне день.
{applicationId}
==
com.companyName.application
добавить ".provider"
который будет ==
com.example.test.provider
в xml
authorities:com.example.test.provider
в действии
Uri mPath = FileProvider.getUriForFile(this, "com.example.example.provider", imageFile);
что решило мою проблему:
замените файл приложения paths на это: посмотрите на корень файлов, я определил путь с именем моего пакета приложения, измените имя pkg на ваше.
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-path
name="files_root"
path="Android/data/com.my.newproject4" />
<external-path
name="external_files"
path="." />
</paths>
а также в вашем провайдере используйте имя вашего пакета вместо ${applicationId}
такой же, как я здесь
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="com.my.newproject4.provider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths" />
</provider>
это то, что сработало со мной, единственное решение и способ после долгих попыток и поиска, именно в этом была проблема
может быть это поможет кому-то я надеюсь для тебя удачи
Это из-за разницы между авторитетными именами
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.provider"
android:exported="false"
android:grantUriPermissions="true"
>
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths"
/>
</provider>
here Look
<pre>android:authorities="${applicationId}.provider" </pre>
Здесь имя органа - это ваш packagename.provider (com.example.app.provider)
val uri: Uri? = FileProvider.getUriForFile(
this.contexts,
BuildConfig.APPLICATION_ID + ".provider",
file
)
всякий раз, когда мы копируем и вставляем код, авторитет может быть изменен с одного источника на другой. в stackoverflow некоторые разработчики помещают манифест ${applicationId}.provider", а в uri помещают (.fileprovider) FileProvider.getUriForFile (this.contexts, BuildConfig.APPLICATION_ID +" .fileprovider", file) теперь проблема в другом. что отображается в журнале
Недавно я преобразовал свой модуль приложения в библиотечный модуль, где онпришлось удалить из моегоbuild.gradle
файл (модуля, который я преобразовал из модуля приложения в модуль библиотеки).
Ниже приведен тег поставщика файла в преобразованном библиотечном модуле.
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileprovider"
android:exported="false"
android:grantUriPermissions="true"
tools:replace="android:authorities">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths"
tools:replace="android:resource" />
</provider>
Теперь новый модуль приложения, в котором я использую библиотеку, имеет другойв этом . Итак, нам нужно принять новыйapplicationId
везде, где мы используем полномочия, необходимы в коде.
Илиandroid:authorities
в библиотекеAndroidManifest
необходимо изменить, чтобы сделать его точно таким же, как иFileProvider
полномочия, используемые в нашем коде.
Пример использования:
Uri photoURI = FileProvider.getUriForFile(this, Constants.ExternalFileProviderAuthority, f);
mImageFromCamera = FileProvider.getUriForFile(это, BuildConfig.APPLICATION_ID + ".fileprovider", mImageFile);android: functions ="${applicationId}.fileprovider "
полномочия должны быть одинаковыми в xml и в коде
Сначала вы используете
File(getExternalFilesDir(null),context?.getString(R.string.app_name));
вместо
Environment.getExternalStorageDirectory(), context?.getString(R.string.app_name) // this is deprecated in API29
тогда используйте это
Uri contentUri = getUriForFile(getContext(), "com.mydomain.fileprovider", newFile);
Для получения дополнительной помощи: Описание поставщика файлов
Чтобы (исправление «Не удалось найти метаданные для поставщика с полномочиями»), которое появляется, когда вам нужно открыть камеру из веб-просмотра во Flutter для Android.
Сначала напишите манифест внутри тега
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths" />
</provider>
Затем создайте папку xml в res и создайте файлProvider_paths.xml, а затем скопируйте и вставьте код:
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-path name="external_files" path="." />
</paths>
Вы можете заменить свой
BuildConfig
имя файла класса импорта:
import androidx.multidex.BuildConfig;
с участием:
import com.yourAppName.BuildConfig;
Напишите следующий тег в манифесте под<application>
ярлык:
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.imagepickerprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/imagepicker_provider_paths" />
</provider>
Затем создайте папку XML в res и создайте файл с именемimagepicker_provider_paths.xml
а затем скопируйте и вставьте код:
<?xml version="1.0" encoding="utf-8"?>
<paths>
<cache-path name="cacheDir" path="." />
</paths>
Его файловый провайдер, а не провайдер
android:authorities="${applicationId}.fileprovider"
Я только что удалил символ '$' из android: rules="${applicationId}.provider", и теперь он работает как шарм.
Измените полномочия на уникальное имя, чтобы решить проблему, например
android:authorities="${applicationId}.myUniquefileprovider"
также в коде Java