我有一个数据库表来存储我的模板(.docx文件)。我使用openTbs来处理模板。我需要的是取出模板并将其存储在服务器本身,并使用openTbs进行编辑。
我的问题是我如何从数据库中检索.docx文件并将其存储在服务器端。 (存储可能是暂时的,但我想使用openTbs进行编辑。)
提前致谢.......
答案 0 :(得分:1)
将二进制数据保存在数据库中是不好的做法,主要是当这些数据打算由文件服务器处理时,例如图片或DOCX。
无论如何,自OpenTBS 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);
...