要在Python中创建一个简单的流媒体服务器来播放FLV(Flash Video)文件,你通常需要一个HTTP服务器,该服务器能够处理对FLV文件的范围请求(Range Requests),因为流媒体通常不是一次性下载整个文件,而是按需下载文件的某一部分。
不过,Python标准库中的http.server
模块可能不足以直接支持范围请求。但是,你可以使用一些第三方库,如Flask
或CherryPy
,并添加自定义逻辑来处理这些请求。
以下是一个使用Flask
的简单示例,展示了如何创建一个能够处理范围请求的流媒体服务器:
-
首先,确保你已经安装了Flask:pip install flask
-
使用以下代码创建一个简单的Flask应用 flask_flv.py :
python# -*- coding: utf-8 -*- """ flask: 为了网页能播放视频流,提供 video/x-flv """ import os from flask import Flask, request, Response, stream_with_context from flask import render_template, send_file, send_from_directory app = Flask(__name__) @app.route('/favicon.ico') def favicon(): return send_from_directory(os.path.join(app.root_path, 'static'), 'favicon.ico', mimetype='image/vnd.microsoft.icon') @app.route('/flv/', methods=['GET']) def index(): return render_template("flvPlayer.html") @app.route('/videos/<path:filename>') def video_file(filename): """ 假设视频文件存储在 Flask 应用的 videos 目录下 """ return send_from_directory('videos', filename, as_attachment=True) @app.route('/stream/<filename>') def stream_video(filename): def generate(): with open(f'videos/{filename}', 'rb') as f: while True: data = f.read(4096) if not data: break yield data return Response(stream_with_context(generate()), mimetype='video/x-flv', headers={ 'Content-Disposition': 'inline; filename="%s"' % filename, 'X-Content-Type-Options': 'nosniff' }) if __name__ == '__main__': app.run(host='127.0.0.1', port=5555, debug=True)
运行 python flask_flv.py 注意 :上面的代码并没有处理范围请求,它只是一个简单的流媒体示例。为了处理范围请求,你需要添加更多的逻辑来解析HTTP头部的
Range
字段,并根据该字段发送文件的相应部分。 -
处理范围请求的完整实现可能相当复杂,并且超出了这个简单示例的范围。但是,你可以考虑使用像
Gunicorn
这样的WSGI HTTP服务器,它可以与Flask一起使用,并且可能已经具有处理范围请求的功能。或者,你可以查看其他现有的流媒体服务器解决方案,如Nginx
与rtmp-module
一起使用,或者专门的流媒体服务器软件,如Wowza Streaming Engine
或Red5
。如果你只是想快速测试FLV文件的流媒体播放,你也可以考虑使用现有的在线服务或工具,如 VLC Media Player 的HTTP流功能。请参阅:简单的http-flv服务器
编写 flvPlayer.html 如下
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title> flv.js 播放器</title>
<script src="https://cdn.jsdelivr.net/npm/flv.js@latest/dist/flv.min.js"></script>
</head>
<body>
<video id="video1" width="1000" height="576" controls ></video>
<script>
if (flvjs.isSupported()) {
var video1 = document.getElementById('video1');
var flvplayer = flvjs.createPlayer({
type: 'flv', // 媒体类型: auto, flv, mp4
isLive: false, // 是否是直播流,默认 true
url: 'http://127.0.0.1:8080/test.flv'
});
flvplayer.attachMediaElement(video1);
flvplayer.load(); // 加载流
flvplayer.play(); // 播放流
}
</script>
</body>
</html>
用 Chrome 浏览器访问 http://localhost:5555/flv/ 可以播放,测试 Edge 不支持。
5. 也可以用 ffplay 测试是否能播放
ffplay -i http://127.0.0.1:8080/test.flv