(PECL mongo >=0.9.0)
MongoGridFS::storeFile — Сохраняет файл в базе данных
$filename
[, array $metadata
= array()
[, array $options
= array()
]] ) : mixed
filename
Наименование файла или читаемого потока для хранения.
metadata
Другие поля метаданных для включения в файл документа.
Замечание:
Данные поля могут перезаписать поля, автоматически созданные драйвером, как указано в основной документации MongoDB » коллекции файлов. В качестве практического применения данного поведения можно указать собственный chunkSize или _id для файла.
options
Массив опций для операций вставки, выполняемых для коллекций chunks и files. Смотрите MongoCollection::insert() для документации по этим параметрам.
Возвращает _id сохраненного документа. Это будет сгенерированный MongoId, за исключением случая, когда _id был явно указан в параметре metadata
.
Выдает исключение MongoGridFSException,
если при чтении filename
или вставке
в коллекции chunks или files возникает ошибка.
Пример #1 MongoGridFS::storeFile() с дополнительными метаданными
<?php
$m = new MongoClient();
$gridfs = $m->selectDB('test')->getGridFS();
$id = $gridfs->storeFile('example.txt', array('contentType' => 'plain/text'));
$gridfsFile = $gridfs->get($id);
var_dump($gridfsFile->file);
?>
Результатом выполнения данного примера будет что-то подобное:
array(7) { ["_id"]=> object(MongoId)#6 (0) { } ["contentType"]=> string(10) "plain/text" ["filename"]=> string(11) "example.txt" ["uploadDate"]=> object(MongoDate)#7 (0) { } ["length"]=> int(26) ["chunkSize"]=> int(262144) ["md5"]=> string(32) "c3fcd3d76192e4007dfb496cca67e13b" }