Ошибка open () в NGINX (20: не каталог) hls vod с модулем защищенной связи


14

У меня проблема с конфигом nginx для потоковой передачи hls. Я использую модуль kaltura nginx vod и пытаюсь добавить его ngx_http_secure_link_moduleдля защиты потока. Странная вещь, у меня ошибка 404, если я включаю ngx_http_secure_link_module(журналы ниже). Я думаю, это потому, что он не может найти файл с index.m3u8 в конце, но если я прокомментирую блокировку защищенной ссылки, он будет работать нормально.

Также я попытался добавить псевдоним внутри location ~ \.m3u8$ {}блока, но это не сработало. Что я делаю неправильно? Как защитить мой поток?

Ссылка на мой поток: https://stream.example.com/hls/c14de868-3130-426a-a0cc-7ff6590e9a1f/index.m3u8?md5=0eNJ3SpBd87NGFF6Hw_zMQ&expires=1609448340

Мой конфиг 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; }
    }
  }
}

Журналы NGINX:

cmdlogs

Ответы:


1

Просто переместил этот блок в каталог сервера и добавил vod hls;внутрь.

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

  if ($secure_link = "") { return 403; }
  if ($secure_link = "0") { return 403; }
}
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.