Как устранить ошибку подключения при попытке потокового видео с YouTube? - PullRequest
0 голосов
/ 12 июня 2019

Я пытаюсь транслировать видео с YouTube в приложении с графическим интерфейсом, используя модули PyQt5, python-vlc и pafy, но vlc выдает мне некоторые ошибки подключения:

[0000025466dc7340] main tls client error: connection error: Interrupted function call
[0000025466df9f00] access stream error: HTTP connection failure
[0000025466dc7430] gnutls tls client error: TLS handshake error: Error in the push function.
[0000025466dc7430] main tls client error: TLS session handshake error
[0000025466dc7430] main tls client error: connection error: Interrupted function call
[0000025466dfa080] access stream error: HTTP connection failure

Когда я делаю то же самое сМодуль ткинтер работает без проблем.Как я могу решить эти ошибки?

def OnYT(self):
    text = self.textbox.text()
    url = self.Search(text) #this function returns the first result url from a search on YouTube 
    self.textbox.setText("")
    video = pafy.new(url)
    best = video.getbest()
    self.mediaplayer.set_mrl(best.url)

    if sys.platform.startswith('linux'):
        self.mediaplayer.set_xwindow(self.videoframe.winId())
    elif sys.platform == "win32":
        self.mediaplayer.set_hwnd(self.videoframe.winId())
    elif sys.platform == "darwin":
        self.mediaplayer.set_nsobject(int(self.videoframe.winId()))

    self.mediaplayer.play()

1 Ответ

0 голосов
/ 12 июня 2019

для этого есть обходной путь, вы можете настроить VLC для подключения к URL, используя http, используя параметр vlc.Instance("prefer-insecure")

, или вы можете попробовать обновить VLC и заполнить его сертификатами:

 sudo update-ca-certificates --fresh --verbose
 mkdir -p ~/.local/share/vlc/certs/
 cat /usr/share/ca-certificates/mozilla/* | tee ~/.local/share/vlc/certs/ca-certifcates.crt

вы можете найти больше информации здесь

Опции GNUtls:

 --gnutls-system-trust, --no-gnutls-system-trust 
                             Use system trust database
                             (default enabled)
      Trust the root certificates of Certificate Authorities stored in the
      operating system trust database to authenticate TLS sessions.
  --gnutls-dir-trust <string> 
                             Trust directory
      Trust directory
  --gnutls-priorities {PERFORMANCE,NORMAL,SECURE128,SECURE256,EXPORT} 
                             TLS cipher priorities
      Ciphers, key exchange methods, hash functions and compression methods
      can be selected. Refer to GNU TLS documentation for detailed syntax.

вы можете использовать --gnutls-dir-trus, чтобы указать на сертификаты Firefox, я думаю

...