Простое приложение, которое служит файлам по http с аутентификацией

Скрипты оболочки очень похожи на команды, которые вы попадаете в типичном режиме в оболочке. В этом случае параметр -O -O G ++ , где поставить двоичный. Таким образом, вы просто скажете это, вы хотите, чтобы в двоичном каталоге:

g++ lesson01.cpp -o Binary/lesson01

Вы можете запустить это интерактивно (набрав его в оболочку), или вы можете поставить, что в сценарии оболочки - оба сделают то же самое:

#!/bin/sh
g++ lesson01.cpp -o Binary/lesson01

Обычно, однако, вы бы использовали Makefile, чтобы делать такие вещи, а не скрипт оболочки.

all:

Binary/%: %.cpp
    g++ -o "$@" "$<"  # Note: this must be a tab, not spaces. Make is annoying like that

Тогда вы напечатаете сделать двоичный / урок01 и сделать компиляцию программы (если источник новее, чем существующий двоичный файл, или если двоичный не существует). Вы также можете перечислить все программы после этого Все: вверху ( все: двоичный / урок01 двоичный / урок02 , и т. Д.) А затем просто набрать make Составьте все программы по мере необходимости.

Вы также можете сделать более продвинутые вещи с помощью Sake или скрипта Shell (например, чтобы он определил список программ для компиляции, а не в списке их всех), но это более сложная.

0
02.05.2015, 17:15
1 ответ

Вы можете использовать любой веб-сервер для списка содержимого HTTP и базовую аутентификацию. Базовая аутентификация безопасна, но вы должны отправлять ее через туннель SSL. Для вашей домашней системы самостоятельно подписанные сертификаты, вероятно, хватит для защиты запросов аутентификации. Я бы порекомендовал Lighttp или Nginx, если вы используете встроенную аппаратное обеспечение, поскольку веб-серверы на основе процесса (Apache в настройке по умолчанию) будут использовать больше ресурсов для каждого соединения. Основным отличием между легкими и NGINX является то, что слегка использует один процесс, и один неблокирующий нить и NGINX использует основной процесс для делегирования работы для детей.

Вот пример /etc/nginx.conf (без тестирования, поэтому может понадобиться подстройка). Вам просто нужно было бы создать папку в / etc / nginx / TLS и добавить самозаписанную SSL Keypair к нему (cert.pem, cert.key).

user  nobody;
worker_processes  1;
events {
  worker_connections  64;
}
http {
  default_type      application/octet-stream;
  log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                    '$status $body_bytes_sent "$http_referer" '
                    '"$http_user_agent" "$http_x_forwarded_for"';
  access_log        var/log/nginx/access.log  main;
  keepalive_timeout 60;
  server {
    server_name                 localhost;
    listen                      80 443;
    ssl                         on;
    ssl_certificate             tls/cert.pem;
    ssl_certificate_key         tls/cert.key;
    ssl_session_timeout         5m;
    ssl_protocols               TLSv1;
    ssl_ciphers                 HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers   on;

    location / {
      root   /path/to/your/data;
      autoindex on;
    }
  }
}
0
28.01.2020, 04:57

Теги

Похожие вопросы