Вызов функции КаталогВременныхФайлов() (TempFilesDir)¶
Тип | Поддерживаются языки |
Важность | Включена по умолчанию |
Время на исправление (мин) |
Теги |
---|---|---|---|---|---|
Дефект кода |
BSL |
Важный |
Да |
5 |
standard badpractice |
Описание диагностики¶
При использовании метода ПолучитьИмяВременногоФайла() платформа 1С:Предприятие сохраняет контроль над такими файлами и автоматически удаляет их при перезапуске рабочего процесса (если файл был создан на стороне сервера) или клиентского приложения (если файл был создан на стороне клиента).
Если же имя временного файла было сформировано каким-то другим способом, и прикладной код не удалил (либо по какой-то причине не смог удалить) ранее созданный временный файл, то платформа такой файл не контролирует, и он остается в файловой системе на неопределенное время. Накапливание «потерянных» временных файлов может представлять серьезную проблему, особенно для информационных баз с большим количеством активно работающих пользователей (например, при работе в режиме сервиса).
Примеры¶
Неправильно:
Каталог = КаталогВременныхФайлов();
ИмяФайла = Строка(Новый УникальныйИдентификатор) + ".xml";
ИмяПромежуточногоФайла = Каталог + ИмяФайла;
Данные.Записать(ИмяПромежуточногоФайла);
Правильно:
ИмяПромежуточногоФайла = ПолучитьИмяВременногоФайла("xml");
Данные.Записать(ИмяПромежуточногоФайла);
Для создания временного каталога рекомендуется также использовать имя, полученное при помощи метода ПолучитьИмяВременногоФайла (исключение составляет веб-клиент).
Неправильно:
Архив = Новый ЧтениеZipФайла(ИмяФайлаАрхива);
КаталогАрхива = КаталогВременныхФайлов()+"main_zip\";
СоздатьКаталог(КаталогАрхива);
Архив.ИзвлечьВсе(КаталогАрхива);
Правильно:
Архив = Новый ЧтениеZipФайла(ИмяФайлаАрхива);
КаталогАрхива = ПолучитьИмяВременногоФайла() + "\main_zip\";
СоздатьКаталог(КаталогАрхива);
Архив.ИзвлечьВсе(КаталогАрхива);
Источники¶
Сниппеты¶
Экранирование кода¶
// BSLLS:TempFilesDir-off
// BSLLS:TempFilesDir-on
Параметр конфигурационного файла¶
"TempFilesDir": false