使用flask将服务器端的视频通过网页在本地查看

原理:把视频变成一个网页直播流,使用 Flask 框架将 OpenCV 的每一帧图片通过 HTTP 协议发给浏览器。

  1. 服务器安装Flask:

    pip install flask

  2. 编写并运行"推流脚本"

在服务器上创建一个新文件,例如web_show.py(记得修改成自己的视频地址):

python 复制代码
import cv2
from flask import Flask, Response
import time

app = Flask(__name__)

# ================= 配置区 =================
# 如果你想测试摄像头,写 0
# 如果是视频文件,写文件路径,例如 'test_video.mp4'
VIDEO_SOURCE = 'test_video.mp4' 
# =========================================

def generate_frames():
    # 初始化视频源
    cap = cv2.VideoCapture(VIDEO_SOURCE)
    
    if not cap.isOpened():
        print(f"无法打开视频源: {VIDEO_SOURCE}")
        return

    while True:
        success, frame = cap.read()
        if not success:
            # 视频播完后,重置到开头循环播放(可选)
            cap.set(cv2.CAP_PROP_POS_FRAMES, 0)
            continue

    
        cv2.putText(frame, "Running on Server", (50, 50), 
                    cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2)
        # =================================================

        # 将 OpenCV 图像编码为 JPEG 格式
        ret, buffer = cv2.imencode('.jpg', frame)
        if not ret:
            continue
            
        frame_bytes = buffer.tobytes()

        # 使用生成器流式输出
        yield (b'--frame\r\n'
               b'Content-Type: image/jpeg\r\n\r\n' + frame_bytes + b'\r\n')

@app.route('/video_feed')
def video_feed():
    return Response(generate_frames(),
                    mimetype='multipart/x-mixed-replace; boundary=frame')

@app.route('/')
def index():
    return "<h1>视频流服务运行中...</h1><img src='/video_feed' width='640'>"

if __name__ == '__main__':
    # host='0.0.0.0' 表示允许局域网/外网访问
    print("服务已启动!请在浏览器访问 http://<服务器IP>:5000")
    app.run(host='0.0.0.0', port=5000, debug=False)
  1. 在本地(wins)观看

步骤运行后,终端会显示:

我们在本地浏览器网址输入:http://10.3.86.255:5000

就能看到视频了!!

相关推荐
小码哥_常27 分钟前
Java后端定时任务抉择:@Scheduled、Quartz、XXL - Job终极对决
后端
不只会拍照的程序猿30 分钟前
《嵌入式AI筑基笔记02:Python数据类型01,从C的“硬核”到Python的“包容”》
人工智能·笔记·python
uzong32 分钟前
Skill 被广泛应用,到底什么是 Skill,今天详细介绍一下
人工智能·后端·面试
Jay_Franklin39 分钟前
Quarto与Python集成使用
开发语言·python·markdown
小码哥_常1 小时前
Kafka平替!SpringBoot+Redis Stream+消费组打造极致消息队列
后端
Oueii1 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
2401_831824962 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
njidf2 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
@我漫长的孤独流浪2 小时前
Python编程核心知识点速览
开发语言·数据库·python
宇擎智脑科技2 小时前
A2A Python SDK 源码架构解读:一个请求是如何被处理的
人工智能·python·架构·a2a