Nginx部署私有Web播放器全指南

1. 概述

本文档旨在指导如何在 Nginx 服务器上部署私有 Web 播放器(基于 hancplayer),并通过 WebSocket 协议接入 RTMS 流媒体服务器,实现低延迟视频实时监控。

2. 前置准备

  • Web 服务器:Nginx (已安装并运行)
  • 流媒体服务:RTMS 服务器 (已运行,端口 5555)
  • 前端文件
    • index.html (播放页面)
    • hancplayer.js (播放器主逻辑)
    • hancmedia.js (媒体处理模块)
    • hancmedia.wasm (WebAssembly 解码核心)

3. 部署步骤

3.1 文件上传

将以下四个文件上传至 Nginx 的站点根目录(例如 /usr/share/nginx/html 或自定义目录),确保它们处于同级目录

  • index.html
  • hancplayer.js
  • hancmedia.js
  • hancmedia.wasm

3.2 关键配置:添加 WASM MIME 类型支持

⚠️ 重要:浏览器加载 .wasm 文件时,要求服务器返回正确的 Content-Type。若未配置,播放器将无法初始化解码器。

验证并重载 Nginx

# 检查配置语法 sudo nginx -t # 重载配置使生效 sudo nginx -s reload

添加映射规则
在 types { ... } 代码块内添加以下行:

types { # ... 其他现有配置 ... application/wasm wasm; }

编辑 Nginx 配置文件
打开全局 MIME 类型配置文件(通常位于 /etc/nginx/mime.types

sudo vim /etc/nginx/mime.types

3.3 修改 HTML 引用路径

编辑 index.html 文件,将播放器脚本的引用地址指向您的 Nginx 服务器地址。

修改前:

<script src="./hancplayer.js"></script>

修改后(示例):

<!-- 将 IP 和端口替换为您实际的 Nginx 地址 --> <script src="http://192.168.0.141:8080/hancplayer.js"></script>

(注:如果 index.html 也托管在同一 Nginx 下,也可以直接使用相对路径 ./hancplayer.js,但需确保所有资源都在同一域下以避免跨域问题)


4. 播放测试

4.1 访问播放页面

在浏览器中访问部署好的 Nginx 地址:

http://192.168.0.141:8080/

(请根据实际 IP 和端口调整)

4.2 输入播放地址

在页面提供的输入框中,填入 RTMS 服务器生成的 WebSocket 播放地址。

URL 格式模板:

ws://<RTMS服务器IP>:<WS端口>/play.pro?cmd=live&ip=<设备IP>&port=<设备端口>&user=<用户名>&pass=<密码>&ftype=<厂家类型>&chan=<通道号>&stream=<码流类型>

测试用例:
假设 RTMS 服务器 IP 为 192.168.0.14,摄像头信息如下:

  • 设备 IP: 192.168.0.222
  • 设备端口: 8000 (海康默认)
  • 用户名: admin
  • 密码: 123456
  • 厂家类型: 0 (海康)
  • 通道号: 1
  • 码流: 0 (主码流)

完整播放地址:

ws://192.168.0.14:5555/play.pro?cmd=live&ip=192.168.0.222&port=8000&user=admin&pass=123456&ftype=0&chan=1&stream=0

4.3 开始播放

  1. 将上述地址粘贴到网页输入框中。
  2. 点击 “实时播放” (或对应按钮)。
  3. 若配置正确,视频画面将在 1-2 秒内加载出来。

5. 常见问题排查 (FAQ)

Q1: 控制台报错 Failed to compile WebAssembly 或 Incorrect response MIME type

  • 原因:Nginx 未识别 .wasm 后缀,返回了错误的 Content-Type。
  • 解决:请严格检查 步骤 3.2,确认 mime.types 中已添加 application/wasm wasm; 且 Nginx 已重载。
  • 验证方法:在浏览器 F12 -> Network 标签页,点击 hancmedia.wasm 请求,查看 Response Headers 中的 Content-Type 是否为 application/wasm

Q2: 视频黑屏或一直加载中

  • 检查网络连通性:确保运行浏览器的电脑能 ping 通 RTMS 服务器 (192.168.0.14) 和 Nginx 服务器 (192.168.0.141)。
  • 检查防火墙:确认 RTMS 服务器的 5555 端口和 Nginx 的 8080 端口已在防火墙放行。
  • 检查参数:确认 URL 中的设备 IP、账号密码、通道号是否正确。可先用 VLC 测试 RTSP 地址是否可用。

Q3: 浏览器控制台报 CORS (跨域) 错误

  • 原因index.html 所在的域名/端口 与 hancplayer.js 或 WS 地址不一致。
  • 解决
    • 尽量让所有资源(HTML, JS, WASM)托管在同一个 Nginx 站点下(同源)。
    • 如果必须跨域,需在 Nginx 配置中添加 add_header Access-Control-Allow-Origin *;

Read more

Flutter 三方库 flad_cli 的鸿蒙化适配指南 - 实现 Dart 工程的自适应模板扫描与脚手架自动化、支持端侧资源一键生成与代码架构规约校验实战

Flutter 三方库 flad_cli 的鸿蒙化适配指南 - 实现 Dart 工程的自适应模板扫描与脚手架自动化、支持端侧资源一键生成与代码架构规约校验实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 flad_cli 的鸿蒙化适配指南 - 实现 Dart 工程的自适应模板扫描与脚手架自动化、支持端侧资源一键生成与代码架构规约校验实战 前言 在进行 Flutter for OpenHarmony 的企业级项目矩阵开发时,如何保证上百个模块的目录结构、基础依赖、甚至是 import 规约保持高度一致?手动复制粘贴模板显然不可持续。flad_cli 是一个专为 Dart 项目设计的极简脚手架(Scaffold)命令行工具。它能根据预设规则自动生成或扫描工程文件。本文将探讨如何在鸿蒙端利用此工具构建极致的工业化开发流水线。 一、原直观解析 / 概念介绍 1.1 基础原理 flad_cli 建立在“代码生成(Code Gen)”与“扫描(

By Ne0inhk
Actix-web 性能优化技巧:从原理到实践

Actix-web 性能优化技巧:从原理到实践

引言 Actix-web 作为 Rust 生态中性能最优秀的 Web 框架之一,其设计充分利用了 Rust 的零成本抽象和 Actor 模型的优势。然而,即使使用如此高性能的框架,不当的使用方式仍然会导致性能瓶颈。本文将深入探讨 Actix-web 的性能优化技巧,从底层原理出发,结合实际案例展示如何充分释放框架潜力。 核心优化原理 Actix-web 的性能优势源于其异步运行时和工作线程池的精心设计。它使用 Tokio 作为异步运行时,采用多线程模型处理请求。理解这一点对于优化至关重要:每个工作线程都有自己的 event loop,阻塞操作会直接影响该线程处理其他请求的能力。 性能优化的第一要务是避免在异步上下文中执行阻塞操作。常见的陷阱包括同步数据库查询、文件 I/O、CPU 密集型计算等。这些操作应该被妥善处理,要么使用异步版本,要么转移到专门的线程池中执行。 实践一:连接池优化 数据库连接是 Web 应用中最常见的性能瓶颈。合理配置连接池参数能显著提升吞吐量: useactix_web:

By Ne0inhk

前端大屏可视化自适应怎么做,零基础入门到精通,收藏这篇就够了

前端数据大屏自适应设计方案全解析 在前端数据大屏的开发中,自适应设计是关键环节,它能确保大屏在不同设备和屏幕尺寸上都能呈现出良好的视觉效果和交互体验。除了常见的 transform: scale、rem/vw、Flex/Grid 等方案外,还有其他有效的方法可以实现自适应。下面为您详细介绍这些方案及其优缺点,以便您根据项目需求做出合适的选择。 一、多种自适应方案详解 (一)transform: scale 整体缩放方案 此方案的原理是先按照特定的设计稿尺寸(如 1920×1080)完成页面容器的开发,在运行时通过 transform: scale() 对整个页面进行缩放操作,从而使其适配不同的屏幕尺寸。 优点: 1. 实现过程简单快捷,能够迅速适配各种分辨率的屏幕,大大缩短开发周期。 2. 无需对原有的页面布局和样式进行大规模修改,减少了开发工作量。 缺点: 1. 缩放后,页面元素可能会出现模糊的情况,影响整体的视觉质量和用户体验。 2. 鼠标事件的坐标与实际视觉位置不一致,容易导致点击偏移问题,影响交互的准确性。 3. 在某些浏览器中,

By Ne0inhk