Evgenii Legotckoi
Evgenii Legotckoi22 січня 2017 р. 03:05

Django - Підручник 019. Налаштування протоколу HTTPS на сайті Let`s Encrypt

Вчора отримав лист щастя від Google , оскільки користуюсь Google Search Console для відстеження індексації сайту в пошуковій системі Google. Суть листа полягає в тому, що Google Chrome повідомлятиме про небезпеку сайту, який використовує протокол http на тих сторінках, де потрібне введення пароля. А якщо врахувати, що на моєму сайті форма авторизації розташовується на всіх сторінках, значить попередження буде на всіх сторінках сайту. Не найприємніша ситуація, тому довелося швиденько діставати сертифікат SSL і налаштовувати https.

На даний момент існує центр сертифікації "Let`s Encrypt", який видає безкоштовні сертифікати терміном на 90 днів. Цей центр сертифікації підтримується такими організаціями, як Electronic Frontier Foundation (EFF), Mozilla Foundation, Akamai, Cisco Systems.

Процес отримання та встановлення сертифіката автоматизований, але у випадку з сайтом, що працює на Django і Nginx, потрібно буде додатково попрацювати над налаштуваннями сервера Nginx.


Отримання сертифіката

Для отримання сертифікату та оновлення в автоматичному режимі використовується програмне забезпечення Certbot. На сайті Let`s encrypt є посилання на це програмне забезпечення, де можна вибрати тип вашої операційної системи та сервер, який використовується за віддачу контенту на вашому сайті. У моєму випадку це Nginx та Ubuntu 16.04 .

Там же буде інструкція з встановлення та процесу отримання сертифіката.

Для встановлення програмного забезпечення сертифікації скористаємося наступною командою:

sudo apt-get install letsencrypt 

Далі необхідно отримати сертифікат за допомогою плагіну webroot наступною командою:

sudo letsencrypt certonly --webroot -w /var/www/example -d example.com -d www.example.com 

Де вказується каталог для сертифікації вашого сайту, в даному випадку /var/www/example , його необхідно буде створити відповідні домени, для яких Ви отримуєте сертифікати.

У цьому випадку є один аспект. Вже на цьому кроці необхідно налаштовувати Nginx , оскільки в каталозі /var/www/example буде створюватись прихований каталог .well-known , який потрібний для отримання сертифіката. Докладніше про початкове настроювання Nginx можете прочитати у відповідній статті .

Тому попередньо налаштовуємо Nginx , як показано нижче та перезапускаємо його.

server {
    listen 80;
    listen [::]:80;
    server_name example.com;

    location /.well-known {
        alias /var/www/example/.well-known;
    }

    location / {
        proxy_pass http://127.0.0.1:8000;
        proxy_set_header Host $server_name;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

Тоді Ви успішно отримаєте Ваш SSL сертифікат.

Налаштуйте протокол https

Після того, як ми отримали сертифікат, необхідно налаштувати протокол https, а для цього необхідно відкрити на сервері 443 порт.

sudo ufw allow 443/tcp

І налаштувати Nginx.

server {    
    listen 80;
    listen [::]:80;
    listen 443 ssl;
    listen [::]:443 ssl;
    server_name example.com;

    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;  

    location /.well-known {
        alias /var/www/example/.well-known;
    }

    location / {
        proxy_pass http://127.0.0.1:8000;
        proxy_set_header Host $server_name;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

В даному випадку вказуються шляхи до ваших сертифікатів і порти на яких сервер чекатиме підключення.

Налаштування підключення за http

Чи залишати можливість підключення за http протоколом для користувачів - це вирішувати вже Вам, але який сенс залишати можливість роботи по даному протоколу, якщо вже є https. Тому зробимо редирект користувача зі сторінок з http на ту саму сторінку з https .

server {
    listen 80;
    listen [::]:80;
    server_name example.com;
    return 301 https://$server_name$request_uri;
}

server {
    listen 443 ssl;
    listen [::]:443 ssl;
    server_name example.com;

    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;  


    location /.well-known {
        alias /var/www/example/.well-known;
    }

    location / {
        proxy_pass http://127.0.0.1:8000;
        proxy_set_header Host $server_name;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

Перезапускаємо Nginx і переконуємося, що при спробі підключення http нас автоматично перенаправляє на з'єднання https .

Автоматичне оновлення сертифіката

Для оновлення сертифіката використовується така команда:

letsencrypt renew 

Але процес можна автоматизувати за допомогою cron (програма-демон, призначена для виконання завдань у певний час, або через певні проміжки часу).

Для редагування cron від root користувача виконаємо таку команду:

sudo crontab -e

Буде наданий вибір між можливими редакторами, вибирайте свій редактор до смаку. А я користуюсь nano. Після чого вставте наступний рядок у конфіг cron.

30 2 * * 1 /usr/bin/letsencrypt renew >> /var/log/letsencrypt-renew.log

У цьому випадку по понеділках о 2:30 буде спроба продовження сертифікату.

Коригування контенту

Останнє, що залишилося, - це коригування всіх посилань на сайті. Тобто необхідно поміняти http на https, щоб внутрішня лінківка сайту не створювала додаткових перенаправлень.

Для Django рекомендую VDS-сервера хостера Timeweb .

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

ArtDev
  • 02 червня 2017 р. 14:58

Добрый день хочу обновить сертификат, но получаю следующее

The following certs are not due for renewal yet: /etc/letsencrypt/live/mysite_ru/fullchain.pem (skipped) No renewals were attempted
. Как правильно обновить сертифика, подскажите? Может что в конфиге поправить?
Evgenii Legotckoi
  • 03 червня 2017 р. 02:34

Добрый день. Либо webroot не отработал как следует, либо вы где-то в настройке http накосячили. Смотрите строчки, где указывается путь к ssl сертификату в конфиге nginx.

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
AD

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:50бали,
  • Рейтинг балів-4
m
  • molni99
  • 26 жовтня 2024 р. 01:37

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:80бали,
  • Рейтинг балів4
m
  • molni99
  • 26 жовтня 2024 р. 01:29

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:20бали,
  • Рейтинг балів-10
Останні коментарі
ИМ
Игорь Максимов22 листопада 2024 р. 11:51
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZE19 жовтня 2024 р. 08:19
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов05 жовтня 2024 р. 07:51
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas505 липня 2024 р. 11:02
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi
Evgenii Legotckoi24 червня 2024 р. 15:11
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey115 листопада 2024 р. 06:04
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProject04 червня 2022 р. 03:49
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
9
9Anonim25 жовтня 2024 р. 09:10
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

Слідкуйте за нами в соціальних мережах