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