Seekbar Not Working In Chrome
Solution 1:
Properly served files for HTML video need to use HTTP Byte Serving, which allows the browser to request just the part of the file that it needs to let you watch the video. If you don't have this, you run into problems like this one.
When you skip forward in a video past the parts that are buffered, the browser can ask the server for the video file from that point forward, skipping the beginning. You may have noticed in the days when most web video players used Flash, especially on Vimeo, you had to wait until most of the video file was buffered before you could seek ahead, because those Flash players didn't support this feature.
The browser requests the file in this format by using the "Ranges" header. The server should respond with a "206 Partial Content" status code, some HTTP headers about the range data, and only a subset of the actual file. Your server is responding with a standard 200 status response. Here's a more detailed article about this process if you're interested.
http://benramsey.com/blog/2008/05/206-partial-content-and-range-requests/
I don't know much about Windows Storage, but it appears that it does support this feature. You may need to check your version and your configuration. These articles may point you in the right direction:
http://msdn.microsoft.com/en-us/library/windowsazure/ee691967.aspxhttp://blogs.msdn.com/b/windowsazurestorage/archive/2011/09/15/windows-azure-blobs-improved-http-headers-for-resume-on-download-and-a-change-in-if-match-conditions.aspx
Good luck.
Solution 2:
The issue here is that a brand new AZURE storage account default implementation does not support supplying the correct headers "Accept-Ranges: bytes" in the HTTP response for the HTTP 206 Partial Content
To fix this you will need to set the DefaultServiceVersion for your storage account to version 2013-08-15 or later. In their documentation, they say this was officially supported in version 2011-08-18, but in my testing, I do not see it until I set it to version 2013-08-15. In the end, I just updated it to the latest version 2019-02-02. I will show you how to do that in a moment.
With that said here are some steps you can take to test and verify this and then how to fix it.
Create a brand new AZURE storage account, add a new container and then upload an MP4 to that container. To see the default headers for your MP4 run the following curl command
curl -I https://<StorageAccount>.blob.core.windows.net/<YourContainer>/<Your>.mp4
Here are the headers you should see your response
HTTP/1.1200OKContent-Length:8655515Content-Type:video/mp4Last-Modified:Fri,29Nov2019 21:45:12 GMTETag:0x8D7751569DECA07Server:Windows-Azure-Blob/1.0Microsoft-HTTPAPI/2.0x-ms-request-id:cc44ae3e-b01e-00b5-2337-e4372d000000x-ms-version:2009-09-19x-ms-lease-status:unlockedx-ms-blob-type:BlockBlobAccess-Control-Expose-Headers:x-ms-request-id,Server,x-ms-version,Content-Type,Last-Modified,ETag,x-ms-lease-status,x-ms-blob-type,Content-Length,Date,Transfer-EncodingAccess-Control-Allow-Origin:*Date:Sat,15Feb2020 19:36:37 GMT
You will see that the following header is missing is
Accept-Ranges: bytes
You can then verify this header will return when you run the following curl command
curl -I -H x-ms-version:2013-08-15 https://<StorageAccount>.blob.core.windows.net/<YourContainer>/<Your>.mp4
To permanently set the storage account version I used LinqPad and the following code with a reference to the Windows.Azure.Storage Nuget Pacakge
var connectionString = "DefaultEndpointsProtocol=https;AccountName=<YourAcountName>;AccountKey=<YourAccountKey>;";
var storageAccount = CloudStorageAccount.Parse(connectionString);
var blobClient = storageAccount.CreateCloudBlobClient();
var props = await blobClient.GetServicePropertiesAsync();
props.Dump(); /* Here you will see that the DefaultServiceVersion is null*/
props.DefaultServiceVersion = "2019-02-02";
await blobClient.SetServicePropertiesAsync(props);
The first time you run this you will see that the DefaultServiceVersion is null. If you run this a second time you will then see the DefaultServiceVersion will be the version you set.
If you then run the curl command again.
curl -I https://<StorageAccount>.blob.core.windows.net/<YourContainer>/<Your>.mp4
You will see the following headers, which now includes the "Accept-Ranges: bytes" header and your seek will work.
HTTP/1.1200OKContent-Length:8655515Content-Type:video/mp4Last-Modified:Fri,29Nov2019 21:45:12 GMTAccept-Ranges:bytesETag:"0x8D7751569DECA07"Server:Windows-Azure-Blob/1.0Microsoft-HTTPAPI/2.0x-ms-request-id:b95228de-f01e-0135-4596-e5d2d2000000x-ms-version:2019-02-02x-ms-creation-time:Fri,29Nov2019 21:45:12 GMTx-ms-lease-status:unlockedx-ms-lease-state:availablex-ms-blob-type:BlockBlobx-ms-server-encrypted:truex-ms-access-tier:Hotx-ms-access-tier-inferred:trueDate:Mon,17Feb2020 13:33:00 GMT
Solution 3:
As @Craig Selbert said, new Azure storage accounts don't support the "Accept-Ranges: bytes" header. You can fix that by setting the DefaultServiceVersion in the Azure Cloud Shell like:
$ctx = New-AzStorageContext -ConnectionString "[connectionstring]"
Update-AzStorageServiceProperty -ServiceType Blob -DefaultServiceVersion 2019-02-02 -Context $ctx
Where [connectionstring] comes from the "Access Keys" tab in the Storage Account.
Post a Comment for "Seekbar Not Working In Chrome"