复制并粘贴的值帐户SID替换的占位符文本TWILIO_ACCOUNT_SID
.
然后,导航到控制台的API密钥部分并生成新的API密钥。复制API键的值(同suddenionosphericdisturbance)电离层的突然骚扰和秘密替换的占位符文本TWILIO_API_KEY_SID
和TWILIO_API_KEY_SECRET
.
接下来,如果你还没有带短信功能的aTwilio电话号码,你需要买一个。在此了解如何购买Twilio电话号码。如果你已经有一个Twilio电话号码,它会显示在帐户信息部分,如上面的截图所示。复制此值,并使用它来替换的占位符文本TWILIO_PHONE_NUMBER
.
非常重要的是确保这些私有凭据的安全并且不受版本控制,所以如果您正在使用Git,请创建一个_。被增加_文件放在项目的根目录下。您可以在这里列出希望git忽略的文件和目录,以免被跟踪或提交。打开。被增加_在代码编辑器中,将。包封/包围(动词envelop的简写)_文件,如下所示:
.env
现在您已经准备好开始构建您的Flask应用程序了。
构建Flask服务器
创建并打开一个名为_app.py_。这是包含所有Python代码的文件。要设置这个项目,您需要创建一个新的Flask应用程序实例、一个Twilio客户机实例和一个新的TinyDB数据库。
由于这是一个小的教程项目,我们将把数据存储在TinyDB JSON文件中。但是,如果您决定进一步开发这个项目,您可能希望为您部署到生产环境的版本选择不同的数据库。
里面的_app.py_,粘贴以下代码:
import os
from dotenv import load_dotenv
from flask import Flask, render_template, request, abort
from twilio.rest import Client
from tinydb import TinyDB, Query
load_dotenv()
TWILIO_ACCOUNT_SID = os.environ.get(‘TWILIO_ACCOUNT_SID’)
TWILIO_API_KEY_SID = os.environ.get(‘TWILIO_API_KEY_SID’)
TWILIO_API_KEY_SECRET = os.environ.get(‘TWILIO_API_KEY_SECRET’)
TWILIO_PHONE_NUMBER = os.environ.get(‘TWILIO_PHONE_NUMBER’)
client = Client(TWILIO_API_KEY_SID, TWILIO_API_KEY_SECRET, TWILIO_ACCOUNT_SID)
db = TinyDB(‘office_hours.json’)
app = Flask(__name__)
@app.route(‘/’)
def index():
return render_template(‘index.html’)
使用这段代码,您已经创建了一个新的Flask应用程序,其中包含必要的导入、您在上一步中设置的环境变量、一个新的Twilio客户端实例和一个新的数据库。您现在还有一条路线(使用app.route()
decorator ),它将呈现一个名为_index.html_,它将包含应用程序的HTML。因为您还没有该文件,所以创建新的_index.html_文件在_模板_目录现在。打开文件并粘贴以下HTML代码:
Office Hours
Create Office Hours Chat
{% if status and status.video_room %}
Success! Office hours room: {{status.video_room.name}} ✅
{% endif %}
这个应用程序的UI并不复杂。它包括一个表单,允许用户输入他们的姓名、电话号码和他们希望接待人们的办公时间视频室的名称。它还有一个显示状态消息的部分,让用户知道房间是否创建成功。在这个HTML文件中,您还引用了一个_样式. css_文件—让我们现在创建它。
创造_static/styles.css_并粘贴以下CSS样式:
.container {
margin-top: 20px;
font-family: sans-serif;
}
h1 {
text-align: center;
}
form {
text-align: center;
}
.data-field {
margin-bottom: 0.5em;
}
input {
padding: 0.6em;
border: 2px solid rgb(177, 189, 233);
border-radius: 5px;
vertical-align: middle;
font-size: 14px;
}
input:focus {
outline: 0;
border-color: #0e364d;
}
label {
text-align: right;
display: inline-block;
width: 6em;
margin: 0 1em 0 0;
}
button {
padding: 0.75em 1em;
border: none;
background-color: rgb(27, 111, 189);
border-radius: 4px;
font-size: 100%;
color: rgb(255, 255, 255);
margin: 0.5em auto;
}
button:focus,
button:hover {
background-color: rgb(88, 166, 240);
}
button:active {
background-color: rgb(177, 189, 233);
}
#status {
margin: 0.5em auto;
text-align: center;
color: rgb(13, 73, 32);
}
现在你的应用看起来更有趣了。
是时候运行你的服务器了。但是,在此之前,在项目的根目录下创建一个名为_。flaskenv_。这是为烧瓶配置添加环境变量的地方。打开_。flaskenv_并添加以下几行:
FLASK_APP=app.py
FLASK_ENV=development
然后,在您的终端中,通过运行以下命令启动服务器:
flask run
一旦服务器启动,您将看到如下日志:
(venv) [office-hours] flask run
* Serving Flask app ‘app.py’ (lazy loading)
* Environment: development
* Debug mode: on
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
* Restarting with stat
* Debugger is active!
* Debugger PIN: 290-231-040
如果您打开浏览器http://localhost:5000/,您将能够在那里看到应用程序:
既然已经设置了前端代码,那么是时候编写Python函数了,这些函数将实际控制视频房间的创建以及当有人加入房间时SMS的发送。
创建一个带有自定义超时的视频室
让我们定义一个名为get_or_create_room()
这将调用Twilio视频室API来获取或创建视频室。将以下代码粘贴到_app.py_要创建函数:
@app.route(‘/’, methods=[‘POST’])
def get_or_create_room():
identity = request.form.get(‘identity’).strip() or None
phone = request.form.get(‘phone’).strip() or None
room_name = request.form.get(‘room_name’).strip() or None
if identity is None or phone is None or room_name is None:
abort(400, ‘Missing one of: identity, phone, room_name’)
Try to get the room if it exists
video_room_list = client.video.rooms.list(limit=20)
found_video_rooms = [room for room in video_room_list if room.unique_name == room_name]
video_room = found_video_rooms[0] if found_video_rooms else None
request_url = request.url_root
callback_url = f’{request_url}message’
if video_room and video_room.status_callback != callback_url:
abort(400, ‘Status callback URL has changed; please create a room with a different name’)
If the room does not exist, create a new one
if not video_room:
video_room = client.video.rooms.create(
unique_name=room_name,
empty_room_timeout=60,
unused_room_timeout=60,
status_callback=callback_url,
status_callback_method=‘POST’,
)
office_hours_appointment = {
‘identity’: identity,
‘phone’: phone,
‘room_name’: video_room.unique_name,
‘room_sid’: video_room.sid
}
Check whether a record for this office hours meeting already exists
office_hours_meeting = Query()
selected_meeting = db.get(office_hours_meeting.room_sid == video_room.sid)
If a record does not exist, insert a new one
if not selected_meeting:
db.insert(office_hours_appointment)
return render_template(‘index.html’, status={
‘video_room’: {
‘sid’: video_room.sid,
‘name’: video_room.unique_name,
‘empty_room_timeout’: video_room.empty_room_timeout,
‘unused_room_timeout’: video_room.unused_room_timeout,
‘status_callback’: video_room.status_callback
}
})
该函数获取应用程序客户端发送的数据,并验证所需的一切都存在。然后,它获取视频房间名称的变量,并检查是否已经存在同名的活动房间。如果不存在,将使用输入的房间名称创建一个新房间。
该函数的一个关键部分是设置unused_room_timeout
和empty_room_timeout
。默认情况下,通过Rooms API创建的新的空视频室将保持活动状态5分钟,以便人们加入。如果没有人加入房间,它将关闭并需要重新创建。您可以通过设置unused_room_timeout
。该值表示无人加入时房间保持活动状态的分钟数。在办公时间房间的例子中,我们将这个值设置为60,这样即使没有人出现,房间也可以开放一个小时。您可以根据自己的喜好随意设置这个值。
另一个价值,empty_room_timeout
,用于设置在最后一个参与者离开后房间应该保持开放多长时间。在办公时间房间的情况下,房间的负责人可能希望在另一个参与者加入时加入房间,在他们的谈话结束后离开房间,然后在另一个参与者加入时再次进入房间。对于这个项目,我们已经设置了empty_room_timeout
到60分钟,但是你可以根据自己的喜好随意定制。
这个函数的另一个重要部分是我们在哪里设置一个status_callback
。这是一个URL,您的应用程序将通过它接收视频房间内发生的事件的状态信息。房间状态回叫事件的完整列表可以在这里找到。对于这个项目,我们将只跟踪participant-connected
事件,因为当有人加入视频房间时,我们希望通知房间创建者,以便他们也可以加入。应用程序将从请求的获取页面地址url_root
并添加/message
route,您将在下一步中创建它。
如果您想了解更多关于视频室的资源属性,请查看这里是Rooms REST API的文档 .
有人加入视频室时发送短信
是时候创建一条路由了,当有人加入视频室时,这条路由将向视频室的创建者发送短信。在…里_app.py_,在下面get_or_create_room()
,粘贴以下内容/message
路线和send_participant_notification()
功能:
@app.route(‘/message’, methods=[‘POST’])
def send_participant_notification():
event = request.values.get(‘StatusCallbackEvent’)
if event == ‘participant-connected’:
room_sid = request.values.get(‘RoomSid’)
office_hours_meeting = Query()
Query for the video meeting by its sid
selected_meeting = db.get(office_hours_meeting.room_sid == room_sid)
participant = request.values.get(‘ParticipantIdentity’)
room_name = selected_meeting.get(‘room_name’)
phone = selected_meeting.get(‘phone’)
identity = selected_meeting.get(‘identity’)
Send an SMS to the creator of the video meeting
client.messages.create(
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)
衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
[外链图片转存中…(img-cFWXtb1J-1712999984119)]
[外链图片转存中…(img-qX25miQ4-1712999984119)]
[外链图片转存中…(img-Llp9zoAz-1712999984120)]
[外链图片转存中…(img-PHq2JFQC-1712999984120)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)