В ColdFusion 9 у нас есть данные в формате PDF, хранящиеся в большом двоичном объекте в базе данных.
Как мне получить это в переменной cfpdf? Кажется, что все параметры требуют имени файла. Есть ли способ сделать это без записи файла?
В ColdFusion 9 у нас есть данные в формате PDF, хранящиеся в большом двоичном объекте в базе данных.
Как мне получить это в переменной cfpdf? Кажется, что все параметры требуют имени файла. Есть ли способ сделать это без записи файла?
CFPDF
и CFDOCUMENT
предназначены для динамического создания и изменения PDF. Поскольку у вас уже есть PDF-файл в виде большого двоичного объекта в вашей базе данных, вам просто нужна страница CF, чтобы отправить ее обратно как часть ответа с использованием CFCONTENT
. Предполагая, что вы используете некоторый тип идентификатора для ссылки на PDF-файл, который вы хотите получить из своей базы данных, пример будет выглядеть так:
<cfquery name="qryFile" datasource="MyDatasourceHere">
SELECT id, name, data
FROM files
WHERE id = <cfqueryparam cfsqltype="cf_sql_integer" value="#URL.id#" />
</cfquery>
<cfheader name="content-length" value="#ArrayLen(qryFile.data)#" />
<cfheader name="content-disposition" value="attachment; filename=#qryFile.name#" />
<cfcontent type="application/octet-stream" variable="#qryFile.data#" />