Android Studio MediaStore Storage не может получить доступ к папкеAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Android Studio MediaStore Storage не может получить доступ к папке

Сообщение Anonymous »

При попытке скачать и сохранить файл выдает ошибку

Код: Выделить всё

Primary directory file not allowed for content://media/external/downloads;
allowed directories are [Download]
Как это исправить, может нет разрешения?

Код: Выделить всё

val multipartBuilder = MultipartBody.Builder().setType(MultipartBody.FORM)

multipartBuilder.addFormDataPart("oid", orderId)

val client = OkHttpClient.Builder()
.connectTimeout(120, TimeUnit.SECONDS)
.writeTimeout(120, TimeUnit.SECONDS)
.readTimeout(120, TimeUnit.SECONDS)
.build()

val request = Request.Builder()
.url(Api.API_URL + "order/shopOrderPrintAgreement")
.addHeader("Authorization", "Bearer ${Api.token}")
.post(multipartBuilder.build())
.build()

val response = client.newCall(request).execute()

/**
*TODO починить для android 10
*/
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
val resolver = context!!.contentResolver
val contentValues = ContentValues().apply {
put(MediaStore.DownloadColumns.DISPLAY_NAME, "agreement_$orderId")
put(MediaStore.DownloadColumns.MIME_TYPE, "application/pdf")
put(MediaStore.DownloadColumns.RELATIVE_PATH, "file/Peshkariki")
}
// MediaStore.Images.Media.EXTERNAL_CONTENT_URI
val uri = resolver.insert(
MediaStore.Downloads.EXTERNAL_CONTENT_URI,
contentValues
)

if (uri != null) {
try {
resolver.openOutputStream(uri).use {
it?.let {
val sink = it.sink().buffer()
sink.writeAll(response.body()!!.source())
sink.close()
}
}

mainActivity.runOnUiThread {
dialog?.dismiss()
try {
val intent = Intent(Intent.ACTION_VIEW)
intent.setDataAndType(
uri, "application/pdf"
)
intent.addFlags(Intent.FLAG_ACTIVITY_NO_HISTORY)
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION)

if (isActivityForIntentAvailable(intent)) {
startActivity(intent)
} else {
val webIntent = Intent(Intent.ACTION_VIEW)
webIntent.setDataAndType(
uri, "text/html"
)
webIntent.addFlags(Intent.FLAG_ACTIVITY_NO_HISTORY)
webIntent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION)
startActivity(webIntent)
}
} catch (e: Exception) {
e.printStackTrace()
Toast.makeText(
mainActivity,
"Не удалось открыть файл",
Toast.LENGTH_SHORT
).show()
}
}
} catch (e:  Exception) {
Crashlytics.logException(e)
}
} else {
log("OrderClientFragment error with uri == null")
Crashlytics.log("OrderClientFragment error with uri == null ")
}
Список всех разрешений, которые я объявил в манифесте и использую в своем проекте
Обратная трассировка

Код: Выделить всё

java.lang.IllegalArgumentException: Primary directory file not allowed for content://media/external/downloads; allowed directories are [Download]
at com.android.providers.media.MediaProvider.ensureFileColumns(MediaProvider.java:2117)
at com.android.providers.media.MediaProvider.ensureUniqueFileColumns(MediaProvider.java:1928)
at com.android.providers.media.MediaProvider.insertFile(MediaProvider.java:2495)
at com.android.providers.media.MediaProvider.insertInternal(MediaProvider.java:3254)
at com.android.providers.media.MediaProvider.insert(MediaProvider.java:2903)
at android.content.ContentProvider$Transport.insert(ContentProvider.java:309)
at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:154)
at android.os.Binder.execTransactInternal(Binder.java:1021)
at android.os.Binder.execTransact(Binder.java:994)
2020-05-01 19:05:44.698 7774-7992/com.app.peshkariki E/AndroidRuntime: FATAL EXCEPTION: Thread-20
Process: com.app.peshkariki, PID: 7774
java.lang.IllegalArgumentException: Primary directory file not allowed for content://media/external/downloads; allowed directories are [Download]
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:170)
at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:140)
at android.content.ContentProviderProxy.insert(ContentProviderNative.java:481)
at android.content.ContentResolver.insert(ContentResolver.java:1828)
at com.app.peshkariki.i.i$n0.run(OrderClientFragment.kt:778)
778 строка, это

Код: Выделить всё

val uri = resolver.insert(
MediaStore.Downloads.EXTERNAL_CONTENT_URI,
contentValues
)
Похоже, что в проекте используются все необходимые разрешения, поэтому я даже не знаю, в каком направлении искать решение этой проблемы

Подробнее здесь: https://stackoverflow.com/questions/615 ... the-folder
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»