【发布时间】:2020-04-05 03:19:19
【问题描述】:
我在 AWS 上运行 RHEL 8 的机器上运行基于 apache2 的 SSL 服务器。我正在尝试在此服务器上部署一个 facebook webhook。我正在使用 curl 请求手动测试它。当我通过 HTTP 输入请求时,它的行为与预期一致。但是,当通过 HTTPS 发出请求时,我收到以下错误消息:
curl: (35) error:1408F10B:SSL routines:ssl3_get_record:wrong version number
我需要让它在 HTTPS 上工作,因为 facebook 不允许仅使用 HTTP 连接。
任何建议都会很棒,谢谢 - 如果我问得不好,我很抱歉,这是我的第一个问题。
webhook 的代码如下:
// Imports dependencies and set up http server
const
express = require('express'),
bodyParser = require('body-parser'),
app = express().use(bodyParser.json()); // creates express http server
// Sets server port and logs message on success
app.listen(process.env.PORT || 1337, () => console.log('webhook is listening'));
// Creates the endpoint for our webhook
app.post('/webhook', (req, res) => {
let body = req.body;
// Checks this is an event from a page subscription
if (body.object === 'page') {
// Iterates over each entry - there may be multiple if batched
body.entry.forEach(function(entry) {
// Gets the message. entry.messaging is an array, but
// will only ever contain one message, so we get index 0
let webhook_event = entry.messaging[0];
console.log(webhook_event);
});
// Returns a '200 OK' response to all requests
res.status(200).send('EVENT_RECEIVED');
} else {
// Returns a '404 Not Found' if event is not from a page subscription
res.sendStatus(404);
}
});
// Adds support for GET requests to our webhook
app.get('/webhook', (req, res) => {
// Your verify token. Should be a random string.
let VERIFY_TOKEN = "duckgoesquack"
// Parse the query params
let mode = req.query['hub.mode'];
let token = req.query['hub.verify_token'];
let challenge = req.query['hub.challenge'];
// Checks if a token and mode is in the query string of the request
if (mode && token) {
// Checks the mode and token sent is correct
if (mode === 'subscribe' && token === VERIFY_TOKEN) {
// Responds with the challenge token from the request
console.log('WEBHOOK_VERIFIED');
res.status(200).send(challenge);
} else {
// Responds with '403 Forbidden' if verify tokens do not match
res.sendStatus(403);
}
}
});
我已尝试更新我的 apache conf 文件 - virtualhosts 部分如下:
NameVirtualHost *:80
<VirtualHost *:443>
ServerName lloydarnoldtestapps.tk
DocumentRoot /var/www/lloydarnoldtestapps.tk
Include /etc/letsencrypt/options-ssl-apache.conf
SSLCertificateFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/privkey.pem
</VirtualHost>
<VirtualHost *:80>
ServerName lloydarnoldtestapps.tk
DocumentRoot /var/www/lloydarnoldtestapps.tk
</VirtualHost>
<VirtualHost *:443>
ServerName www.lloydarnoldtestapps.tk
ServerAlias *.lloydarnoldtestaps.tk
DocumentRoot /var/www/lloydarnoldtestapps.tk
SSLCertificateFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
<VirtualHost *:1337>
ServerName lloydarnoldtestapps.tk
DocumentRoot /var/www/lloydarnoldtestapps.tk
SSLCertificateFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
<VirtualHost *:80>
ServerName www.lloydarnoldtestapps.tk
DocumentRoot /var/www/lloydarnoldtestapps.tk
</VirtualHost>
<VirtualHost *:1337>
ServerName www.lloydarnoldtestapps.tk
DocumentRoot /var/www/lloydarnoldtestapps.tk
SSLCertificateFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/lloydarnoldtestapps.tk/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
【问题讨论】:
-
你可以尝试运行
openssl s_client -connect www.lloydarnoldtestapps.tk -port 443-prexit或-debug -
嗨@Yan,这样做得到了这个响应:``` 139642581512640:error:0200206E:system library:connect:Connection timed out:../crypto/bio/b_sock2.c:110: 139642581512640 :error:2008A067:BIO 例程:BIO_connect:connect 错误:../crypto/bio/b_sock2.c:111:connect:errno=110 --- 没有可用的对等证书 --- 没有发送客户端证书 CA 名称 --- SSL 握手已读取 0 字节并写入 0 字节 验证:OK --- 新,(NONE),密码为 (NONE) 不支持安全重新协商 压缩:NONE 扩展:NONE 未协商 ALPN 未发送早期数据 验证返回码: 0(确定)```
-
我的浏览器中显示了一个挂锁,并且证书在那里被标记为有效。我想知道我是否没有正确设置我的配置文件?如果您有任何很棒的想法 - 谢谢! :) @Yan
-
将
-servername www.lloydarnoldtestapps.tk添加到命令中.. 似乎errno=110the server rejects the connection. If this happens, you receive a message such as connect: Connection timed out or connect:errno=110. -
运行
openssl s_client -connect lloydarnoldtestapps.tk -port 1337 -server lloydarnoldtestapps.tk -debug时会发生什么
标签: node.js apache express ssl webhooks