- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在将财务数据通过电子邮件发送给用户的应用程序中具有导出到 PDF 的功能。我使用我的测试站点获得了这个功能 100% 工作,但是当我部署到我的生产站点时它没有工作。在 prod 站点上,通过电子邮件向用户发送一个空白的 1kb 1 页 PDF 文件(可以在 PDF 查看器中打开)。
这是我如何使用该功能的低点。我用过这个guide让 Nightmare JS 在 Amazon Linux 上运行。
/export
调用xvfb-run
的子进程为 Nightmare JS 创建一个可视帧缓冲区以供使用。exec(`xvfb-run -a --server-args="-screen 0 1366x768x24" node
${path.join(__dirname, 'export.js')} ${process.env.TYPE} ${token}
${req.user.email}`)
Nightmare()
.viewport(1366, 768)
.goto(
`http://localhost:${process.env.PORT}/export_summary_1?
exportToken=${exportToken}`
)
.wait(3000)
.pdf()
.end()
.then(function(pdfBuffer) {
mailOptions.attachments = [{
filename: 'financial_model.pdf',
content: pdfBuffer
}]
email.send(mailOptions)
})
/export_summary_1
浏览器页面使用导出 token 进行另一个服务器调用以加载和显示财务数据。然后,如上面的代码所示,Nightmare 将页面捕获为 PDF,最后将该 PDF 通过电子邮件发送给用户。 http://localhost:[port]/export_summary_1
)。
最佳答案
tldr; NightmareJS 加载了一个空白页面,该页面导出为 PDF,因为有对 https://localhost:3000/bundle.js
的子调用和 https://localhost:3000/styles/style.css
,它们负责所有呈现的无法连接的内容(没有设置 HTTPS 服务器,因为 HTTPS 是通过 AWS 负载均衡器实现的)。
在我的问题中,我提到了我认为导出到 PDF 处理的相关部分都是在本地完成的。实际上就是这种情况,但还有进一步的 HTTP->HTTPS 重定向。以下是 HTTP->HTTPS 重定向代码的外观:
app.use(function(req, res, next) {
if(!req.secure &&
req.get('X-Forwarded-Proto') !== 'https' &&
// above: achieves HTTP->HTTPS redirecting using AWS load balancer and EC2 instance
!/export_summary/.test(req.url)) {
res.redirect('https:' + req.hostname + req.url)
} else {
next()
}
})
// NOTE: all code above is commented out on test site, and uncommented for production site
https://localhost:3000/export_summary
无法到达。所以,我插入了
!/export_summary/.test(req.url)
有条件的,以便 NightmareJS 对
export_summary
的 HTTP 调用页面不会被重定向到 HTTPS 调用。
export_summary
所涉及的子调用。页。所以,资源的两个主要子调用,到
http://localhost:3000/bundle.js
和
http://localhost:3000/styles/style.css
, 被重定向到他们的 HTTPS 对应项。 (注意:在为
<script src='bundle.js'></script>
提供的 HTML 文件中,bundle.js 调用是
/export_summary
。
!/(export_summary)|(exportPrivate)|(bundle\.js)|(style\.css)|(\.png)|(\.ttf)|(\.woff)/.test(req.url))
/export_summary
调用时,服务器会响应一个 index.html 文件,该文件用于部署应用程序(那里也没有 secret 数据)。 关于node.js - 在使用 Nightmare JS 的 AWS 上,导出为 PDF 可以使用一个端口,但不能使用另一个端口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48675145/
我是 javascript 的新手(今天开始弄乱它)。 我正在尝试更改名为“bar”的元素(div)的高度。条形图将成为图表的一部分。 我可以毫无问题地将按钮连接到更改栏高度的函数。一切正常,除了条形
错误 -> “UIVIew”没有名为“addSubView”的成员 override func viewDidLoad() { super.viewDidLoad() // Do an
我在命令行工具项目中复制并粘贴了 main.swift 下面链接中的代码。 How do you use CGEventTapCreate in Swift? 它构建没有错误,但是当我运行时, gua
我在尝试编译我的代码时遇到以下错误。 ERROR! ..\myCode\CPOI.cpp:68:41: error: cannot dynamic_cast 'screenType' (of type
我正在尝试将多个字符串连接到一个我已为其分配内存的字符串指针。这是一个例子: char *finalNumString = malloc(sizeof(char)*1024); finalNumStr
我在使用 dup2() 和 pipe() 时遇到问题。 当我尝试将管道的写入端 dup2 到 STDOUT_FILENO 时,我收到了 EBADF。 我用 gdb 在 dup2(pout[1], ST
首先,我应该说我运行的是 Windows 7。 因此,今天早上我尝试像往常一样从我的存储库中提取数据,但我做不到。我得到了错误: The authenticity of host 'github.co
刚开始在虚拟环境中运行Python,乱用Django,无法激活虚拟环境。 花了最后 4 个小时尝试在本地终端/VS 代码上激活虚拟环境 (venv),但没有成功。 避免使用“sudo pip inst
Tidyverse 的粉丝经常给出使用小标题而不是数据框的几个优点。它们中的大多数似乎旨在保护用户免于犯错误。例如,与数据框不同,小标题: 不需要 ,drop=FALSE不从数据中删除维度的论据。 不
我一直在对 Elm 应用程序进行 docker 化时遇到问题。据我所知,我已经创建了一个完整且有效的 Docker 文件……但它不起作用。 我会解释的。 所以我的脚本在 3 个文件中运行。 首先是启动
我可以在 Controller 中使用@Autowired,例如 @RestController public class Index { @Autowired HttpServlet
我定义了一个方法和一个函数: def print(str:String) = println val intToString = (n:Int) => n.toString 现在我想创作它们。 我的问
当我控制台单独记录变量“pokemons”时,它确实返回一个数组。但是当我尝试映射它时,出现错误: TypeError: pokemons.map is not a function 我的代码: im
每当我尝试在 Python 解释器中导入 smtplib 时,都会收到此错误: ImportError: cannot import name fix_eols 我该如何解决这个问题? 编辑:这是完整
我正在使用 Meteor.js 开发一个项目,但在使用 Handlebar 时遇到了一些问题:我想检索集合的最后一项,并显示字段:其中包含 html 的文本: 这是我的javascript代码: Te
你好,我想使用 Service 实现 GestureDetector 但是我有这个错误The method onTouchEvent(MotionEvent) of type GestureServi
我正在尝试在 Controller bean 中 Autowiring 接口(interface) 在我放置的上下文配置文件中 和 我的 Controller 类是 @Controller pub
我试图在 mainwindow.cpp 中包含 QtSvg,但是当我编译时它说无法打开包含文件:QtSvg。我已经在我的 *.pro 文件中添加了这个(QT += svg)。我可以知道可能是什么问题吗
鉴于以下 PostgreSQL 代码,我认为这段代码不容易受到 SQL 注入(inject)攻击: _filter 'day' _start 1 _end 10 _sort 'article_name
我想执行以下操作。这在 MySQL 中是非法的。 PostGRESQL 中关联的 CTE(“with”子句)有效。这里的假设是 MySQL 中的子查询不是完全限定的 CTE。 请注意:这个查询显然非常
我是一名优秀的程序员,十分优秀!