Embedded YouTube video doesn't work on local server

前端 未结 5 1632
南旧
南旧 2020-12-16 22:29

I saw many questions like this asked on StackOverflow, but none of them had a working answer. My problem is that I can\'t embed a YouTube video, because a \"This video is no

相关标签:
5条回答
  • 2020-12-16 22:42

    Some javascript injection to fix it for people who just want to watch video directly from youtube.com/embed

    document.body.innerHTML = '<iframe id="video" width="560" height="315" src="https://www.youtube.com/embed/_RrA-R5VHQs" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe><style>body{margin; 0; overflow: hidden;}#video{position:absolute;left:0px;width:100%;top:0px;height:100%;}</style>'
    
    0 讨论(0)
  • 2020-12-16 22:46

    This is not Youtube APIs fault. Tried running this on my localhost using "python -m SimpleHTTPServer 8080" and got it running easily. So, I'm concluding that you don't have a proper local web server. Also, "file:///C:/path/to/file.html" will never work because to use any of Google APIs, you need to have access to the internet.

    0 讨论(0)
  • 2020-12-16 22:54

    For some god-forsaken reason, known only to YouTube's engineers, some videos require an HTTP server to play.

    If you're familiar with npm and Node.js, you can follow the instructions here so you can set up an HTTP server and try it out for yourself.

    But please, if you do have the time and willingness, send a bug report about this issue by following the instructions here. This sort of issue should definitely not be happening.

    Best of luck!

    0 讨论(0)
  • 2020-12-16 22:55

    Sergiy Shcherbina's answer helped me solve this issue. I was running my web server from a vm and accessing it through my local IP address.

    It seems that you need to access your page that contains the embedded youtube player through a host name and NOT an IP address.

    How I solved This for my dev environment

    Before the change, I was accessing my web-page like this: http://192.168.x.x:3000/video and i would get 'video unavailable' errors for many videos that were verifiably 'embeddable'.

    A Hacky word-around: I set a hostname for my VM in my hosts file and aliased my IP address to dev-vm. How to edit your host file

    Now i access the page which has my embedded player like this: http://dev-vm:3000/video and now videos that previously gave me a 'video unavailable' error are now playing.

    What a bizarre issue. I hope this helps some people who are having a similar issue.

    0 讨论(0)
  • 2020-12-16 23:03

    It works on sites with domain and does not work on sites reached by IP adress. Works when using on "localhost" and causes "The video is unavailable" when using "127.0.0.1". This is really strange...

    0 讨论(0)
提交回复
热议问题