更新 2 - 2020 年 6 月
此问题最常见的根本原因似乎是服务器未配置为正确处理范围请求。
Safari 期望在发送具有字节范围的请求时看到“206”响应。如果服务器以“200”请求响应,则 Safari 似乎无法处理此问题。其他一些浏览器似乎对此没问题 - 例如 Chrome。
下面的检查网络选项卡屏幕截图显示了成功的视频播放,其中包含范围请求和 206“部分内容”响应:
虽然下面的示例显示了一个无法在 Safari 中播放但在 Chrome 中播放的视频 - 可以看出服务器只是响应 200 请求:
您可以使用 CURL 命令测试服务器是否正确接受范围请求 - 在此处查看来自苹果的信息:
如果您不确定您的媒体服务器是否支持字节范围请求,您可以在 OS X 中打开终端应用程序并使用 curl 命令行工具从服务器上的文件中下载一小段:
curl --range 0-99 http://example.com/test.mov -o /dev/null
如果工具报告它下载了 100 个字节,则媒体服务器正确处理了字节范围请求。如果它下载整个文件,您可能需要更新媒体服务器。有关 curl 的更多信息,请参阅 OS X 手册页。
(来自:https://developer.apple.com/library/archive/documentation/AppleApplications/Reference/SafariWebContent/CreatingVideoforSafarioniPhone/CreatingVideoforSafarioniPhone.html#//apple_ref/doc/uid/TP40006514-SW6)
对第一个正确播放的视频使用上述参考中的 CURL 命令,我们可以看到响应是请求的范围按预期返回:
使用与上述示例相同的 CURL 命令,该命令在 Safari 中不播放(但在 Chrome 中)表明服务器正在响应完整文件,而不仅仅是请求的范围:
此 CURL 测试可能是检查您的服务器是否正确尝试处理请求的最快方法。
原答案
这似乎是 Safari 上某些 mp4 文件反复出现的问题。
我在 localhost node.js 静态服务器上测试了您的视频,它在 Safari 中播放良好,这意味着视频本身应该没问题。
如果您查看 Safari 中的 Web 检查器,您会发现 Web 请求不包含某些标头。这会导致一些服务器出现问题,并且它们不会按照 Safari 的预期方式响应,或者根本不响应。
您可以看到正在讨论的类似问题(我认为第二个问题不是您的情况,但说明发送到服务器的请求中包含的信息可能导致服务器“决定”不按您的意愿响应):
更新 1:
使用wireshark捕获来自Chrome的请求,可以看出导致服务器响应带有要播放的视频,而来自Safari(在同一台机器上)的请求导致服务器没有响应。
请求通常相似,并且都包含引荐来源标头。 Safari 浏览器最初只要求从服务器返回前 2 个字节 - 它通过使用 'range' 标头来执行此操作,该标头用于指定文件返回的字节范围:
另一方面,Chrome 请求其范围请求中的整个视频:
但是,在 Chrome 上使用 HTTP 工具(例如 Postman)并将范围更改为 0-1 似乎不会停止服务器在 Chrome 案例中的响应。事实上,使用该工具设置,尽可能与 Safari 设置的所有相同标题似乎仍然可以返回视频。