一尘不染

Flask将PDF作为自己的页面进行处理

flask

对于我的个人网站,我想为我的简历准备一个单独的页面,即PDF。我已经尝试了多种方法,但是我无法弄清楚如何使Flask处理PDF。


阅读 1039

收藏
2020-04-06

共1个答案

一尘不染

给任何遇到此问题的人的注释,因为他们试图使用Flask从数据库提供PDF文件。当文件存储在数据库中时嵌入PDF并不像在静态文件夹中时那样简单。你必须使用该make_response函数并为其提供适当的标题,以便浏览器知道如何处理二进制PDF数据,而不是像通常那样从视图函数中返回它。这里有一些伪代码可以帮助你:

from flask import make_response

@app.route('/docs/<id>')
def get_pdf(id=None):
    if id is not None:
        binary_pdf = get_binary_pdf_data_from_database(id=id)
        response = make_response(binary_pdf)
        response.headers['Content-Type'] = 'application/pdf'
        response.headers['Content-Disposition'] = \
            'inline; filename=%s.pdf' % 'yourfilename'
        return response

如果你要下载文件而不是在浏览器中显示文件,则可以将“内容处置”从“内联”更改为“附件”。你也可以将此视图放在子域中,例如docs.yourapp.com而不是yourapp.com/docs。最后一步是将该文档实际嵌入浏览器中。在你想要的任何页面上,只需使用rawrgulmuffin的策略即可:

<embed src="/docs/pdfid8676etc" width="500" height="375">

你甚至可以使用Jinja2模板使src动态化。让我们将其放在doc.html中(注意大括号):

<embed src="/docs/{{doc_id}}">

然后在视图函数中,只需返回具有适当doc_id的渲染模板:

from flask import render_template

@app.route('/<id>')
def show_pdf(id=None):
    if id is not None:
        return render_template('doc.html', doc_id=id)

这会将用户从数据库中请求的文档嵌入到简单的GET请求中。希望这对任何在数据库中处理大量PDF的人有所帮助!

2020-04-06