iOS 不能播放远程视频(Android 可以)的问题

本文探讨了iOS的AVPlayer与Android在播放特定URL的MP4文件时的不同行为。iOS播放失败源于服务器对Range请求的错误响应,而Android则能正常播放。文章深入分析了iOS AVPlayer如何通过Range请求判断文件类型,并提供了正确的后台代码参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:

1、同样的 url,Android 能放,iOS 不能放。后台给的 url 是这个样子(mp4文件格式):

http://192.168.80.102:28085/schcommonweb/weedfs/rdownload/2@8a54d21abc

2、用 KVO 监听 AVPlayerItem 的 status 发现报错:

Code=-11850 Code=-12939 Operation Stopped The server is not correctly configured

3、用浏览器(Safari或者Chrome)直接打开 url,发现也不能播放,而是变成下载。视频文件下载后,可以正常播放,说明 mp4 文件格式也是正确的。

4、但是换一个从网上找的视频 url,却能正常播放。

通过上述问题初步断定应该是后台的问题。于是让后台逐一排查。后来发现,iOS 和 Android 在播放此类 url 时,都会用到 HTTP 1.1 的 Range bytes 头,但二者的行为略有不同:

iOS 的 AVPlayer 在第一次请求时,会发送一个 Range: bytes=0-1 的请求头,此时服务器应该返回 206 和 content-range 及 content-length 响应消息。AVPlayer 用这两个字节的数据来判断文件类型(即 ftyp,请参考 http://www.ftyps.com/),然后后面的请求才是正常的读取视频数据。

而 Android 却不会有读取 ftyp 的过程。

而后台由于粗心的原因,在计算 Range 的时候,不知道为什么会在 iOS 的第一次请求 bytes=0-1 时将 content-length 计算错了,计算成 -1。从而导致 iOS 无法播放而 Android 能正常播放。

正确的后台代码可以参考网上的这篇博客

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值