Python Twilio错误-prolog中不允许包含内容。架构验证警告

Python Twilio错误-prolog中不允许包含内容。架构验证警告,python,python-3.x,twilio,twilio-api,Python,Python 3.x,Twilio,Twilio Api,与前一个类似,我有一个webhook接收器,可以监听帖子。我向我的Twilio号码发送一条WhatsApp消息,Twilio发送到webhook接收器,服务器代码处理请求,然后向Twilio返回一个响应对象。代码从Airtable上的事件日历中提取一些项目,并通过Twilio将它们发送给WhatsApp webhook测试与Postman一致。但是,WhatsApp不会返回POST请求的结果,我从Twilio调试器收到以下警告: sourceComponent "14100&q

与前一个类似,我有一个webhook接收器,可以监听帖子。我向我的Twilio号码发送一条WhatsApp消息,Twilio发送到webhook接收器,服务器代码处理请求,然后向Twilio返回一个响应对象。代码从Airtable上的事件日历中提取一些项目,并通过Twilio将它们发送给WhatsApp

webhook测试与Postman一致。但是,WhatsApp不会返回POST请求的结果,我从Twilio调试器收到以下警告:

sourceComponent     "14100"
line                "1"
ErrorCode           "12200"
LogLevel            "WARN"
Msg                 "Content is not allowed in prolog."
EmailNotification   "false"
parserMessage       "Content is not allowed in prolog."
cols                "1"
我的完整代码如下:

from flask import Flask, request
import requests
import json
from airtable import Airtable
from datetime import datetime
from twilio.twiml.messaging_response import MessagingResponse

base_key = 'BASE_KEY'
table_name = 'Events Calendar'
api_key = 'API_KEY'
airtable = Airtable(base_key, table_name, api_key)

API_URL = "https://api.airtable.com/v0/BASE_KEY/Events%20Calendar?maxRecords=3&filterByFormula=IS_AFTER(%7BDate%7D,NOW())"

headers = {
    "Authorization": "Bearer API_KEY"
}

app = Flask(__name__)

@app.route('/bot', methods=['POST'])
def accessdb():
    incoming_msg = request.values.get('Body', '').lower()
    resp = MessagingResponse()
    msg = resp.message()
    responded = False
    
    if 'next' in incoming_msg:
        def pretty(d):
            date = datetime.strptime(d["Date"], "%Y-%m-%dT%H:%M:%S.%fZ")
            return f'''Date: {date.strftime("%A, %d. %B %Y %I:%M%p")}
Title: {d['Title']}
Description: {d['Description']}
'''
        pages = airtable.get_iter(maxRecords=3, formula="Date >= NOW()", sort=["Date"], fields=('Date', 'Title', 'Description'))
        mylist = [] 
        
        for page in pages:
            for record in page:
                if 'fields' not in record:
                    continue
                fields = record['fields']
                mylist.append(pretty(fields))
        return "\n".join(mylist)

    elif 'what' in incoming_msg:
        msg.body("Please enter 'next' to get the next events.")
        responded = True

    elif not responded:
        msg.body("I don't know about that, sorry!")
    return str(resp)

if __name__ == '__main__':
    app.run()
以上代码已部署到Heroku,我可以使用curl或Postman调用webhook并成功生成以下结果:

Date: Wednesday, 07. October 2020 06:00PM
Title: Social Distancing Dance Party: Slow Motion
Description: Slow Motion is the yang to the Saturday Dance Party's yin

Date: Thursday, 08. October 2020 08:00AM
Title: Free Online Meditation Mornings
Description: 20-30 minute meditation. Donations can be made at https://example.com

Date: Saturday, 10. October 2020 07:00PM
Title: Social Distancing Dance Party
Description: A party in your very own kitchen
但是从Twilio调用webhook会产生前面给出的错误

前面的SO答案建议按如下方式返回查询结果:
return TwiliorResponse.ToString()

我对语法没有信心,并尝试了以下方法:

        for page in pages:
            for record in page:
                if 'fields' not in record:
                    continue
                fields = record['fields']
                mylist.append(pretty(fields))
        return "\n".join.twilioResponse.ToString(mylist)
但是,当我尝试上述方法时,失败如下:

    return "\n".join.twilioResponse.ToString(mylist)
AttributeError: 'builtin_function_or_method' object has no attribute 'twilioResponse'

如果能朝正确的方向轻推,我们将不胜感激。非常感谢。

这里是Twilio开发者福音传道者

我认为这里的问题是,当您发送bot“next”时,它会以一系列结果进行响应,而不是Twilio所期望的结果。如果用户发送“what”或其他信息,那么您将返回TwiML,因此没有太多需要更改的内容

您需要使用以下代码:

对于页面中的页面:
第页记录如下:
如果“字段”不在记录中:
持续
字段=记录['fields']
mylist.append(漂亮的(字段))
返回“\n”。加入(mylist)
将您构建的字符串设置为TwiML响应中的消息,而不是在末尾返回,如下所示:

对于页面中的页面:
第页记录如下:
如果“字段”不在记录中:
持续
字段=记录['fields']
mylist.append(漂亮的(字段))
msg.body(“\n”.join(mylist))
现在,您正在将事件列表设置为要发送的消息,它将通过方法末尾的行
returnstr(resp)
以TwiML的形式返回给Twilio

作为补充,我认为在整个条件语句中不需要使用
responsed
布尔值。相反,您可以使用
else
来完成条件语句,它将捕获您以前未匹配的任何案例。像这样:

其他:
body(“我不知道,对不起!”)

如果有帮助,请告诉我。

您能分享更多的代码吗?现在还不清楚你从哪里得到一些变量,或者你从哪里返回webhook响应。谢谢@philnash-我已经添加了更多信息。非常感谢。谢谢你@philnash-是的,这很有效。太神了我将回顾有关
响应的
布尔值的代码-我已经改编了Flask/Twilio教程。这就是这样一次旅程和学习经历。再次感谢。一个(希望)快速的问题@philnash,请注意-WhatsApp“有益地”扩展了邮件正文中的任何URL。有没有一种方法可以抑制这种行为,因为它会扰乱消息的格式?您可以在URL周围加上背景标记,使其呈现为代码,这可能会抑制URL的展开。虽然我还没试过,但我不能保证它能奏效。看。非常感谢@philnash-我来看看。祝你一切顺利。