这是一个创建于 2636 天前的主题,其中的信息可能已经有所发展或是发生改变。
部署用的 Gunicorn 18.0 和 eventlet 0.20.1。
问题来了:
如果用 eventlet,则在 Chrome 浏览器里直接打开的 make_response 生成的 PDF 文件预览没问题,下载只能下载部分数据,不能下载整个完整的 PDF。
Chrome 在加载完整个 PDF 预览后,点击下载按钮,不是直接从缓存下载的 PDF 么,为什么预览没有问题,下载却下载不完整呢?在 Edge 和 Firefox 中测试都可以完整下载。
但是,如果不使用 eventlet,Chrome 也是可以完整下载的。
这到底是为啥?查看了 Nginx 的 access 日志,Chrome 点击 pdf 上的下载按钮,并没有再访问服务器啊。
2 条回复 • 2017-07-24 06:48:42 +08:00
|
|
1
sivacohan 2017-07-23 07:05:11 +08:00 via Android
Wireshark 抓下包吧,看一下 chrome 在浏览和下载 PDF 的时候所发请求 header 部分有什么不同。再和 Firefox 的 header 比较一下。 我猜问题出在 PDF.js 和 server 端 chuck encoding 这块了
|
|
|
2
julyclyde 2017-07-24 06:48:42 +08:00
chrome 不是从缓存下载的
|