ESP8266 + FLProg – Создание web интерфейса настройки

vacxppea0d9obsjt0rfgwt9zygk.jpeg

Источник

Предыдущий пост, посвящённый связке FLProg и ESP8266, был обзорным, а теперь рассмотрим работу в программе с этим контроллером более подробно.
Как и для ардуино, работа над проектом начинается с выбора контроллера. В отличие от предыдущих версий, для удобства пользователей контроллеры были перенесены в древовидную структуру папок.

qtemhvmnz1gcks891rer76zuc5q.png

При выборе конкретного контроллера или платы можно посмотреть его изображение, распиновку, а так же технические характеристики.

Основная работа при создании web интерфейса настройки производится в дереве проекта.
Для начала настроим точку доступа.

Раскрываем дерево проекта до пункта »Точка доступа» включительно и двойным кликом по ветке »Отключён» включаем точку доступа в работу.

vc_k0sqor8nswajflyzog-3p_54.png

В открывшихся ветках настраиваем параметры точки доступа. Для изменения необходимого параметра производим двойной клик на соответствующей ветке.

smfdjmvambkxygappu2xp4eeo6k.png

Имя сети (SSID) — Имя сети которую будет организовывать точка доступа.
Пароль для подключения — пароль для подключения к точке доступа. Если оставить пустым, то точка доступа будет без пароля со свободным подключением.

IP адрес — IP адрес который будет иметь контроллер в сети созданным точкой доступа. По этому адресу потом можно будет подключиться к контроллеру.

Остальные параметры (Маска подсети и Сетевой шлюз) заполнятся автоматически после установки IP адреса, но при необходимости их можно изменить, если требуются нестандартные значения.

В результате должно получиться, что то подобное.

1zcnnog21frjae812jsohe7dpgs.png

С точкой доступа закончили, можем свернуть этот узел, и переходим к клиенту. Так же разворачиваем его узел, и включаем его в работу двойным кликом по ветке »Отключён»

1ltwvltjejbimxzsdxfhbofz3xg.png

Настраиваем клиента. Возможны два варианта настройки клиента. Непосредственное задание настроек сети, и получение настроек по DHCP. Для начала используем второй вариант.

fk2rtfjtzwlfxlshwmzyseysnu4.png

Обратите внимание, что в целях безопасности пароль подключения в дереве проекта не показывается.

С настройкой Wi-Fi интерфейсов закончили. Сворачиваем (если нужно) узел клиента и переходим к настройке режима обновления прошивки по Wi-Fi (если это требуется). Данный узел появляется только при включённом в работу клиенте.

Включаем этот режим двойным кликом по ветке »Отключён»

u3behj6frqh9tkbnedjhltuudym.png

Задаём необходимые параметры (изменение значения параметров производится с помощью двойного клика на соответствующей ветке).

yfmghw2xuitmr5fmh5slxla0eni.png

Пароль — при задании пароля перед заливкой новой прошивки потребуется его ввод.
Имя устройства — Это имя будет фигурировать в названии порта соединения в Arduino IDE.

Подробнее о режиме Arduino OTA можно почитать здесь.

Теперь переходим непосредственно к созданию web интерфейса настройки. Открываем узел »Web интерфейс настройки» и включаем его двойным кликом по ветке »Отключён»

-wsiqm_d1lek9ywvt_n5fmpyxqs.png

Web интерфейс настроек представляет собой набор страниц с параметрами. Если страниц более одной, автоматически формируется меню для доступа к ним. Для каждой страницы можно задать собственные стили CSS, если использовать общие стили для всего Web интерфейса настройки.
Для настройки общих стилей CSS для всего web интерфейса совершаем двойной клик по ветке »Общий стиль»

oewa3oftjwb0j60x_fxcosaciqo.png

Откроется окно настроек общего стиля.

enujg3lzqnayvm7emma4o2ymqww.png

На закладке »Описание стилей» находится поле ввода непосредственно описания стилей применяемых для всех страниц настройки. По умолчанию это поле уже заполнено стилями для создания стандартного интерфейса. Но если есть желание изменить дизайн страниц, то можно их изменить.

На закладке »Стили» можно задать названия стилей используемых для конкретных элементов страницы.

sq5arsrapovpgj7xu41rab1bhhi.png

Эта закладка так же заполнена по умолчанию.

На закладке »Тексты» можно ввести тексты основных элементов используемых на странице.

d6egkfv_a9axahug1s4oifbsbou.png

Для восстановления всех значений данного диалога значениями по умолчанию, можно воспользоваться кнопкой »По умолчанию».

Настройки стилей и текстов заданные в общих стилей применяются на всех страницах настроек, если они не перекрыты настройками стилей конкретной страницей (это рассмотрим ниже)
Страницы показаны в узле »Страницы настроек». Раскрываем его.

jsw4smdp_kub7fkzqzidms6scnc.png

По умолчанию всегда присутствует одна страница. Раскрыв её узел, получаем доступ к её настройкам.

2wfu_x7gjov1k6pjnab-5aprjv0.png

Адрес главной страницы — адрес основной страницы настроек. По умолчанию — host — то есть адрес контроллера в сети. При необходимости можно сменить. Сменим его на адрес host/setting (двойной клик по данной ветке).

b9pzvzmecok8ayv4u89yjxagqsi.png

Имя страницы — название страницы в меню. Оставим ей название — »Главная»
Стиль страницы — двойной клик по данной ветке вызывает диалог настройки стиля для конкретно этой страницы.

x7ej0m-t4tzwwvmldj6ss1lkgw8.png

2nzlcqiiqga0tgxuw0q6lbw-kr8.png

uhxhebtmcrd7gdvbj0l0lsjop-u.png

В этом диалоге можно дописать дополнительные стили CSS для данной страницы и назначить стили и тексты для элементов дизайна. Так же можно переопреописать стили, описанные в диалоге общих стилей.

В узле »Параметры» задаются параметры, отображаемые на странице. На главной странице мы зададим отображение IP адреса полученного от роутера по DHCP в виде простого текста. Параметр добавляется с помощью двойного клика по ветке »Добавить параметр»

wkp2cbl2f_1zltsjh3ccqbqfgku.png

Открывается диалог создания нового параметра. В нём для начала нажимаем кнопку выбора системного параметра.

kom_ilzized1-tlfmbjlb9lm_jm.png

Откроется список доступных системных параметров. Выбираем параметр »Wi-Fi клиент — IP адрес».

3z_tawjow1knpqgrbtlvz10_bse.png

В поле надписи вводим текст лейблы для этого параметра, а в поле тип параметра выберем значение »Текст»

jqwfeypxqguixhasbx1mcj9hrqa.png

После создания параметра появится новый узел дерева проекта, в котором можно настроить стиль для данного параметра, изменить настройки параметра или удалить его.

e0odeeevsc0afscvyhqyckmp8tc.png

Узлы »Кнопка «Save»» и »Кнопка «Reset»» задают наличие кнопок сохранения данных и перезагрузки контроллера на странице. Поскольку никаких изменяемых данных на главной странице у нас нет, отключим эти кнопки на странице двойным кликом на ветке »Используется» (по умолчанию кнопки присутствуют на странице).

qnefboaiiar9aq0tol-71nns_vu.png

Добавим новую страницу двойным кликом по ветке »Добавить страницу»

7u2wjpp_npsnar7gwikp7hlspro.png

Откроется диалог создания новой страницы. В нём заполним имя страницы (как она будет называться в меню интерфейса настройки) и адрес. Адреса вспомогательных страниц всегда продолжают адрес главной страницы. На данной странице мы будем настраивать параметры точки доступа.

mymiizbdo1jn8j8mkw25oaflhww.png

Так же как и для главной, в узле новой страницы можно поменять адрес страницы, имя, настроить стили для конкретно этой страницы, задать отображаемые параметры и наличие кнопок. Ну и дополнительно есть возможность удаления страницы.

k_s2g983sl9ltmihg9xokp3xo1k.png

Добавим на страницу параметр »Wi-Fi точка доступа — имя сети (SSID)»

wdeqwexhhqft66qf8t5-pyprubu.png

И выберем для него тип »Поле ввода» и лейблу »Имя сети»

2coufednlmnvbyype3mcsgxmj1y.png

Таким же образом добавим остальные параметры точки доступа.

_nnkcnpor5wcofjin-j9atkswvy.png

Если параметров на странице более одного в узлах параметров появляются ветки позволяющие изменить порядок вывода параметров на странице.

Поскольку на странице есть изменяемые параметры, оставим на ней кнопки сохранения и перезагрузки контроллера.

Для данной страницы в диалоге стилей зададим заголовок для данной страницы

hcpfevi7mo58nw4rv3pnalwksbg.png

По такому же сценарию создадим страницу с настройками клиента. Для параметра »Wi-Fi клиент — получение IP по DHCP» зададим тип параметра »Чек бокс»

etwd1mlatb__rgwarrqn8k5u6c0.png

При наличии в интерфейсе более двух страниц в узлах страниц так же появляются ветки управляющие положением страниц в меню интерфейса. Но главная страница всегда остаётся первой.

ywssmpmwv7miknf5xq9_e1euk5g.png

В данный момент доступ к интерфейсу и всем страницам свободный. Введём ограничение доступа. Для этого сделаем двойной клик по ветке »Свободный доступ» узла »Доступ к интерфейсу»

yi7tkkver0xrmhbzbqlzdr4ksng.png

Теперь для доступа к интерфейсу необходимо будет авторизоваться. Время активной авторизации можно задать. По умолчанию оно составляет 15 минут. Через это время после последней активности пользователя будет произведён автоматический сброс текущего пользователя. Это время можно изменить путём двойного клика по соответствующей ветке.

u97skk4w92r2qyayihs8srpw4qs.png

В узле »Пользователи» можно задать необходимое количество пользователей. Там всегда присутствует супер пользователь (по умолчанию логин — admin). Ему всегда доступны все страницы и параметры. Как и для любого пользователя в его узле можно задать логин и пароль.

e0zbstk81ttdhy_gq3nrnhjc2f4.png

Создадим нового пользователя, который будет иметь право настраивать точку доступа. Для этого произведём двойной клик по ветке »Добавить пользователя». Откроется диалог добавления пользователя. В нем мы зададим логин и пароль нового пользователя

nw98zru8dkce5ptu0bb9qbhvtes.png

И создадим ещё одного пользователя, который сможет настраивать клиента.

k9-tyymiirqx4nfshecvb2f0mvw.png

После включения доступа по логину и паролю на всех страницах появилась кнопка »Exit», которая служит для выхода текущего пользователя. Оставим ее на всех страницах.

umcujykpnq095oodj51ee26jsei.png

Теперь настроим доступ на страницах. Главная страница всегда доступна всем пользователям. А в узлах остальных страниц появилась новая ветка »Доступ». Дважды кликнем на этой ветке в узле страницы »Точка доступа».

qejqhdwwseixwiirdmqjonfqjvk.png

Откроется диалог выбора пользователей для доступа к странице. По умолчанию доступ открыт всем пользователям. Снимем галочку с пользователя »User_Client» тем самым ограничив его доступ к данной странице.

2m7ja0vgcvtcng6cd5wr4ux4rdg.png

Таким же способом ограничим доступ к странице настроек клиента пользователю »User_Tochka»

5-5puta4v_gywir3odc3pfzo58y.png

Создадим ещё одну страницу для настроек логинов и паролей

a1j-prh6h2exbh7drmuzlwcp7e8.png

Добавим на эту страницу параметры логинов и паролей для всех пользователей. Эти параметры появились в списке системных параметров после включения доступа по логину и паролю.

vdvoxr-bz0j_31hqxeurlqkbbkc.png

Для данной страницы не будем настраивать ограничение доступа, а настроим ограничение непосредственно на параметры. В узлах параметров появились ветки настройки доступа аналогичные настройкам доступа к страницам.

evvkyqwu-4rqivhv2zrm_4u2mao.png

К параметрам админа запретим доступ обеим пользователям, а к параметрам пользователей оставим доступ только тому пользователю, которому эти параметры принадлежат.

На этом настройку web интерфейса считаем законченной.

Нажимаем кнопку «Компилировать проект» в главном интерфейсе программы и получаем готовый скетчь в Arduino IDE.

dk0mv3xfxljqzvezegovgyrbhew.png

p-iv75qnepibpneektcv1m_mqwy.png

В Arduino IDE выбираем нашу плату.

vbe0dslakbjqelbp6lfuxlc_nxo.png

И порт, к которому подключен контроллер

cgbkrzrge5iivbc79cprct4d3pq.png

После чего заливаем прошивку в контроллер

mhujxgj4rbxbmazopannxzdcv2e.png

Итак, что у нас получилось…

После загрузки появляется новая точка доступа.

e_6etbtwijgg5s__hs_xg4ceaxu.png

Подключаемся к ней и заходим по заданному нами в проекте адресу. Появляется страница авторизации.

ujf6zrlbzhvwcrxoobfrr5ys2tg.png

Вводим пароль и логин администратора, и попадаем на главную страницу

b4kztmadjbwnj6xoajbqjlkpxok.png

Видим в меню все страницы

o11os_ky-mjajporxoajbls1xju.png

1fgx9xsshdwaj5qj1vme29s_y9m.png

А на странице логина и пароля все параметры.

atlje29cbl8bsgihpzow8p2simc.png

Выходим и логинимся под User_Tochka. Видим в меню только доступные страницы, и только свой логин и пароль

e-b0hx1fxeyvra__dvhgntxnaw4.png

Перелогиниваемся под User_Client и картина соответствующая — видим только то, что положено

tjgqg5-76hvk-x7ch8wodf_gkao.png

Открываем Arduino IDE и в настройках порта видим, что контроллер готов к обновлению прошивки «по воздуху».

egi9uilypplmx0vn1vipytig8pe.png

На сегодня всё.

На следующем уроке рассмотрим пользовательские системные параметры, и синхронизацию с серверами точного времени. Скачать проект, созданный на этом уроке, можно здесь.

© Habrahabr.ru