如何使用 react-native-video 获取视频流?
How to get video streaming with react-native-video?
我在 nodejs 上有以下代码的后端,我在其中使用 Range-based 视频流:
router.get('/video/:id', authenticateToken, (req, res) => {
const range = req.headers.range;
if (!range) {
res.status(400).send("Requires Range header");
}
// get video stats (about 61MB)
const videoPath = `uploads/${req.params.id}`;
const videoSize = fs.statSync(videoPath).size;
// Parse Range
// Example: "bytes=32324-"
const CHUNK_SIZE = 10 ** 6; // 1MB
const start = Number(range.replace(/\D/g, ""));
const end = Math.min(start + CHUNK_SIZE, videoSize - 1);
// Create headers
const contentLength = end - start + 1;
const headers = {
"Content-Range": `bytes ${start}-${end}/${videoSize}`,
"Accept-Ranges": "bytes",
"Content-Length": contentLength,
"Content-Type": "video/mp4",
};
// HTTP Status 206 for Partial Content
res.writeHead(206, headers);
// create video read stream for this particular chunk
const videoStream = fs.createReadStream(videoPath, { start, end });
// Stream the video chunk to the client
videoStream.pipe(res);
});
但是 react-native-video 不发送任何范围 Headers 并且当我尝试从服务器获取 mp4 视频时出现错误:
{"error": {"extra": -2147483648, "what": 1}}
使用 react-native-video 包:
<Video
source={{
uri: `http://*server ip*/video/${exercise.content}`,
type: 'mp4',
}}
/>
我应该改用什么?
express static解决了我的问题。感谢@SilvanBregy
app.use('/video', express.static('uploads'))
我在 nodejs 上有以下代码的后端,我在其中使用 Range-based 视频流:
router.get('/video/:id', authenticateToken, (req, res) => {
const range = req.headers.range;
if (!range) {
res.status(400).send("Requires Range header");
}
// get video stats (about 61MB)
const videoPath = `uploads/${req.params.id}`;
const videoSize = fs.statSync(videoPath).size;
// Parse Range
// Example: "bytes=32324-"
const CHUNK_SIZE = 10 ** 6; // 1MB
const start = Number(range.replace(/\D/g, ""));
const end = Math.min(start + CHUNK_SIZE, videoSize - 1);
// Create headers
const contentLength = end - start + 1;
const headers = {
"Content-Range": `bytes ${start}-${end}/${videoSize}`,
"Accept-Ranges": "bytes",
"Content-Length": contentLength,
"Content-Type": "video/mp4",
};
// HTTP Status 206 for Partial Content
res.writeHead(206, headers);
// create video read stream for this particular chunk
const videoStream = fs.createReadStream(videoPath, { start, end });
// Stream the video chunk to the client
videoStream.pipe(res);
});
但是 react-native-video 不发送任何范围 Headers 并且当我尝试从服务器获取 mp4 视频时出现错误:
{"error": {"extra": -2147483648, "what": 1}}
使用 react-native-video 包:
<Video
source={{
uri: `http://*server ip*/video/${exercise.content}`,
type: 'mp4',
}}
/>
我应该改用什么?
express static解决了我的问题。感谢@SilvanBregy
app.use('/video', express.static('uploads'))