当前位置: 首页 > news >正文

使用nodejs和html布局一个简单的视频播放网站,但是使用localhost:端口访问html无法加载视频

js代码:

// app.js
const express = require('express');
const path = require('path');
const app = express();// 设置静态文件目录,这里假设你的视频文件在public/videos/目录下
app.use(express.static(path.join(__dirname, '')));// 设置主页路由,指向一个包含HTML5 video元素的页面
app.get('/', (req, res) => {res.sendFile(path.join(__dirname, 'test.html'));
});// 启动服务器
const PORT = process.env.PORT || 3001;
app.listen(PORT, () => {console.log(`Server is running on http://localhost:${PORT}`);
});

html代码:

<!-- public/views/index.html -->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Video Player</title>
</head>
<body><h1>hello</h1><video width="640" height="360" controls><!-- 视频路径相对于static目录 --><source src="./videos/111.mp4" type="video/mp4"></video><img src="./videos/qq1.png" alt=""></body>
</html>

在vscode中直接打开test.html可以正常加载视频。但是使用node 启动js监听端口然后调用test.html就不行,不能加载html文件。

文件目录结构:

--videos

        --111.mp4

        ---qq1.png

--test.js

--test.html

问题,发现是localhost访问时地址不对。浏览器会直接访问localhost:3001/111.mp4

所以这里需要设置路径映射

其实这段代码:

app.use(express.static(path.join(__dirname, '')));

就是用来设置路径映射的,只是最开始没有设置正确。

这里将代码改为:

app.use(express.static(path.join(__dirname, 'videos')));

将路径映射到videos文件夹,然后就可以读取到videos文件夹下的文件。

修改后代码:

js:

// app.js
const express = require('express');
const path = require('path');
const app = express();// 设置静态文件目录,这里假设你的视频文件在public/videos/目录下
app.use(express.static(path.join(__dirname, 'videos')));// 设置主页路由,指向一个包含HTML5 video元素的页面
app.get('/', (req, res) => {res.sendFile(path.join(__dirname, 'test.html'));
});// 启动服务器
const PORT = process.env.PORT || 3001;
app.listen(PORT, () => {console.log(`Server is running on http://localhost:${PORT}`);
});

html:

<!-- public/views/index.html -->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Video Player</title>
</head>
<body><h1>hello</h1><video width="640" height="360" controls><!-- 视频路径相对于static目录 --><source src="111.mp4" type="video/mp4"></video><img src="./qq1.png" alt=""></body>
</html>

http://www.lryc.cn/news/293654.html

相关文章:

  • 【AG32VF407】国产MCU+FPGA Verilog双边沿检测输出方波
  • [晓理紫]每日论文分享(有中文摘要,源码或项目地址)--强化学习、模仿学习、机器人
  • 为什么说TiDB在线扩容对业务几乎没有影响
  • STM32--SPI通信协议(2)W25Q64简介
  • svn安装与搭建
  • 什么是缓存击穿、缓存穿透、缓存雪崩?
  • springboot153相亲网站
  • CMake生成osg的FFMPEG插件及Windows下不生成VS工程问题解决
  • 代码随想录算法训练营Day25 | 216.组合总和III、17.电话号码的字母组合
  • 故障诊断 | 一文解决,SVM支持向量机的故障诊断(Matlab)
  • 12.1 Web开发_DOMBOM:JS关联CSS(❤❤)
  • scoped样式隔离原理
  • 降价不是杀手锏,和府捞面打起“养生牌”
  • 在WORD中设置公式居中编号右对齐设置方式
  • 如何使用 Supabase Auth 在您的应用程序中设置身份验证
  • 带libc源码gdb动态调试(导入glibc库使得可执行文件动态调试时可看见调用库函数源码)
  • 初级通信工程师-通信动力与环境
  • clickhouse在MES中的应用-跟踪扫描
  • 适用于嵌入式单片机的压缩算法
  • 软件工程(最简式总结)
  • Docker基础(持续更新中)
  • Vue工程引入Element-ui
  • 算法学习——华为机考题库9(HJ56 - HJ63)
  • Maven安装,学习笔记,详细整理maven的一些配置
  • STM32--USART串口(2)串口外设
  • Unity之做一个最简单的FPS游戏demo
  • 【Springboot】单元测试Junit5应用
  • 【INTEL(ALTERA)】内部错误:子系统:PTI,文件:/quartus/tsm/pti/pti_delay_annotator.cpp
  • 大数据 - Spark系列《二》- 关于Spark在Idea中的一些常用配置
  • android 设置未知来源等 AppOpsManager 权限的设置接口