NGINX open () nie powiodło się (20: To nie jest katalog) hls vod z modułem bezpiecznego łącza


14

Mam problem z konfiguracją nginx do przesyłania strumieniowego hls. Używam modułu kaltura nginx vod i próbuję dodać, ngx_http_secure_link_moduleaby chronić strumień. Dziwne jest to, że mam błąd 404, jeśli włączę ngx_http_secure_link_module(dzienniki poniżej). Myślę, że dzieje się tak, ponieważ nie może on znaleźć pliku z indeksem.m3u8 na końcu, ale jeśli skomentuję bezpieczny blok linków, działa dobrze.

Próbowałem także dodać alias w location ~ \.m3u8$ {}bloku, ale to nie działało. Co ja robię źle? Jak chronić mój strumień?

Mój link do strumienia: https://stream.example.com/hls/c14de868-3130-426a-a0cc-7ff6590e9a1f/index.m3u8?md5=0eNJ3SpBd87NGFF6Hw_zMQ&expires=1609448340

Moja konfiguracja NGINX:

server {
  listen 9000;
  server_name localhost;
  # root /srv/static;

  location ^~ /hls/ {
    # the path to c14de868-3130-426a-a0cc-7ff6590e9a1f file
    alias /srv/static/videos/1/;
    # file with cors settings
    include cors.conf;

    vod hls;

    # 1. Set secret variable
    set $secret "s3cr3t";

    # 2. Set secure link
    secure_link $arg_md5,$arg_expires;
    secure_link_md5 "$secure_link_expires $secret";

    # if I comment this block everything works fine (but security)
    location ~ \.m3u8$ {
      if ($secure_link = "") { return 403; }
      if ($secure_link = "0") { return 403; }
    }
  }
}

Dzienniki NGINX:

cmdlogs

Odpowiedzi:


1

Właśnie przeniosłem ten blok do katalogu serwera i dodałem vod hls;do niego.

location ~ \.m3u8$ {
  include cors.conf;
  vod hls;

  if ($secure_link = "") { return 403; }
  if ($secure_link = "0") { return 403; }
}
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.