当您 send the SMS 时,您提供的 URL 为 status_callback:
from twilio.rest import Client
# Your Account Sid and Auth Token from twilio.com/console
# DANGER! This is insecure. See http://twil.io/secure
account_sid = 'ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
auth_token = 'your_auth_token'
client = Client(account_sid, auth_token)
message = client.messages \
.create(
body='McAvoy or Stewart? These timelines can get so confusing.',
from_='+15017122661',
status_callback='http://postb.in/1234abcd',
to='+15558675310'
)
print(message.sid)
因此,不要使用上面的 postb.in URL,而是将其更改为您的 ngrok URL。但是请注意,每次重新启动连接器时,ngrok URL 都会更改,除非在付费计划 (apparently) 上。因此,每次重新启动 ngrok 连接器时,您都需要更改上述代码中的 URL。
考虑到这一点,您可以根据问题中的代码块将单独的应用设置为 handle the callback。
更新
我可以拨打电话,但我仍然遇到 Flask 和回调状态问题。
我没有要测试的 Twillio 帐户,但我会先检查回调请求是否真的到达了您的 Flask 服务器。
我会从文档的代码示例中假设,status_callback URL 为http://postb.in/1234abcd,该请求实际上会到达端点http://postb.in/1234abcd/MessageStatus,但是这可能是一个错误,并且烧瓶代码应该是:@app.route('/1234abcd') 如果你提供了这样的网址。 (这在文档中不太清楚)。
如果您确定请求正在到达服务器,但您的代码没有正确处理它,那么设置catch-all 路由可能是明智之举,例如:
from flask import Flask, request
app = Flask(__name__)
@app.route('/', defaults={'path': ''}, methods=['POST'])
@app.route('/<path:path>', methods=['POST'])
def catch_all(path):
print (path, request.url, request.get_data())
return ('', 204)
这将允许您检查到达服务器的任何请求,无论路径如何。
您还可以使用 requests 库测试这条包罗万象的路线(顺便说一下,不要与 Flask 的 request 对象混淆!):
# From any other terminal
import requests
r = requests.post('http://localhost:5000/',json={1:2})
r = requests.post('http://localhost:5000/asd',data={3:4})
服务器控制台输出:
http://localhost:5000/ b'{"1": 2}'
172.17.0.1 - - [17/Jul/2020 23:11:55] "POST / HTTP/1.1" 200 -
asd http://localhost:5000/asd b'3=4'
172.17.0.1 - - [17/Jul/2020 23:12:00] "POST /asd HTTP/1.1" 200 -