如何在php中将文件从数据库保存到服务器

时间:2013-10-24 13:22:57

标签: php mysql opentbs

我有一个数据库表来存储我的模板(.docx文件)。我使用openTbs来处理模板。我需要的是取出模板并将其存储在服务器本身,并使用openTbs进行编辑。

我的问题是我如何从数据库中检索.docx文件并将其存储在服务器端。 (存储可能是暂时的,但我想使用openTbs进行编辑。)

提前致谢.......

1 个答案:

答案 0 :(得分:1)

将二进制数据保存在数据库中是不好的做法,主要是当这些数据打算由文件服务器处理时,例如图片或DOCX。

无论如何,自Ope​​nTBS 1.8.1起,您可以从PHP文件句柄中打开DOCX(或任何Ms Office,LibreOffie或zip存档)。

您可以使用此功能轻松地从数据库合并您的模板:

// retrieve binary data of the file
$rs = mysql_query($dbc, "SELECT data FROM files WHERE id=$id");
$rec= mysql_fetch_array($rs, MYSQLI_ASSOC);
mysql_free($rs);

// create a temporary file
$temp = tmpfile();
fwrite($temp, $rec['file']);
unset($rec); // free PHP memory

// Open the file with OpenTBS
$TBS = new clsTinyButStrong;
$TBS->Plugin(TBS_INSTALL, OPENTBS_PLUGIN);
$TBS->LoadTemplate($temp);
...