Совместное использование файла журнала с FileProvider не удается - PullRequest
0 голосов
/ 18 октября 2018

Я пытаюсь поделиться своим внутренним лог-файлом с использованием контент-провайдера FileProvider.У меня есть следующая запись <provider> в манифесте:

<provider
    android:name="android.support.v4.content.FileProvider"
    android:authorities="nl.charm.nedradio"
    android:exported="false"
    android:grantUriPermissions="true">
    <meta-data
        android:name="android.support.FILE_PROVIDER_PATHS"
        android:resource="@xml/file_provider_paths" />
</provider>

file_provider_paths.xml содержит:

<?xml version="1.0" encoding="utf-8"?>
<paths>
    <external-files-path name="files" path="." />
</paths>

Код для создания намерения общего ресурса:

private static final String LOGFILE_NAME = "log.txt";
private static final String AUTHORITY = "nl.charm.nedradio";

public static Intent getShareIntent(Context context)
{
    Intent intent = new Intent(Intent.ACTION_SEND);
    intent.setType("text/plain");
    intent.putExtra(Intent.EXTRA_SUBJECT, "Log File");
    intent.putExtra(Intent.EXTRA_TEXT, "App logfile.");

    // Allow access outside of share application's realm
    intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
    intent.setFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION);

    File logFile = new File(context.getExternalFilesDir(null), LOGFILE_NAME);
    Uri logURI = FileProvider.getUriForFile(context, AUTHORITY, logFile);
    intent.putExtra(Intent.EXTRA_STREAM, logURI);

    return intent;
}

Создание намерения работает должным образом, но когда я пытаюсь поделиться, например, с Gmail, я получаю следующую ошибку в logcat:

2018-10-18 10:16:49.536 4585-4585/com.google.android.gm E/Gmail: Gmail:Error adding attachment
    exk: FileNotFoundException when openFileDescriptor.

Я искал ответ, но не смогнайти его.Так какие-нибудь предложения о том, что я делаю не так?

Ответы [ 2 ]

0 голосов
/ 18 октября 2018

Вот похожий вопрос, thers - это картинка , которая есть в моем ответе. Пожалуйста, отметьте этот вопрос , и я обещаю, что это может решить вашу проблему.

<files-path name="name" path="path" />  
Represents files in the files/ subdirectory of your app's internal storage area. This subdirectory is the same as the value returned by Context.getFilesDir().

<external-path name="name" path="path" />
Represents files in the root of the external storage area. The root path of this subdirectory is the same as the value returned by Environment.getExternalStorageDirectory().

<external-files-path name="name" path="path" />
Represents files in the root of your app's external storage area. The root path of this subdirectory is the same as the value returned by Context#getExternalFilesDir(String) Context.getExternalFilesDir(null).
0 голосов
/ 18 октября 2018

После еще нескольких поисков я обнаружил, что я использую неправильное местоположение для сохранения файлов журнала.Чтобы решить эту проблему, мне пришлось внести следующие изменения в конфигурацию logback.xml:

<configuration>

    <property name="LOGFILE_NAME" value="log.txt" />
    <property name="EXT_FILES_DIR" value="${EXT_DIR:-/sdcard}/Android/data/${PACKAGE_NAME}/files" />

    <appender name="rollingfile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${EXT_FILES_DIR}/${LOGFILE_NAME}</file>

        <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
            <fileNamePattern>${LOGFILE_NAME}.%i</fileNamePattern>
            <minIndex>1</minIndex>
            <maxIndex>1</maxIndex>
        </rollingPolicy>

        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <maxFileSize>400KB</maxFileSize>
        </triggeringPolicy>

        <encoder>
            <pattern>%date %-5level %logger{10} - %msg%n</pattern>
        </encoder>
    </appender>

    <root level="TRACE">
        <appender-ref ref="rollingfile" />
    </root>

</configuration>

Соответствующим изменением является значение свойства EXT_FILES_DIR.Теперь будет использоваться внешнее хранилище, доступное для приложения, вместо старого пути /data/data/nl.charm.nedradio/files.

Другое необходимое изменение - в file_provider_paths.xml.Здесь внешний путь изменяется с "." на "/":

<?xml version="1.0" encoding="utf-8"?>
<paths>
    <external-files-path name="files" path="/" />
</paths>

Теперь обмен данными работает, например, с Gmail и Google Drive.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...