[К началу] | [Библиотека Ethernet]
Объект Ethernet инициализирует библиотеку Ethernet и позволяет задать сетевые настройки. Является экземпляром класса EthernetClass.
Метод Ethernet.begin() производит инициализацию библиотеки и позволяет задать сетевые настройки. Вызов метода возможен в одной из нескольких следующих форм:
Ethernet.begin(mac);
Ethernet.begin(mac, ip);
Ethernet.begin(mac, ip, dns);
Ethernet.begin(mac, ip, dns, gateway);
Ethernet.begin(mac, ip, dns, gateway, subnet);
Библиотека Ethernet поддерживает DHCP. Для автоматического получения IP-адреса метод
нужно вызывать в форме Ethernet.begin(mac);
. В этом случае метод возвращает успех
(число 1), если адрес по DHCP получен, и число 0 -- в противном случае. В остальных
вариантах вызова метод ничего не возвращает.
Первый параметр, mac, должен быть массивом из шести беззнаковых байт. Остальные параметры являются объектами класса IPAddress. Допускается передавать вместо экземпляра IPAddress значения, из которых он может быть сконструирован. IPAddress рассматривается ниже.
Рассмотрим назначение этих параметров.
-
mac: MAC-адрес Ethernet Shield.
-
ip: IP-адрес Ethernet Sheild.
-
dns: IP-адрес DNS-сервера; если не задан, то IP-адрес содержит в последнем октете 1.
-
gateway: IP-адрес шлюза; если не задан, то IP-адрес содержит в последнем октете 1.
-
subnet: маска подсети; по умолчанию это 255.255.255.0.
Небольшой пример кода с методом Ethernet.begin():
#include <SPI.h>
#include <Ethernet.h>
byte mac[] = { 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED };
byte ip[] = { 192, 168, 1, 1 };
void setup() {
Ethernet.begin(mac, ip);
}
void loop () {
}
Метод Ethernet.localIP() позволяет узнать IP-адрес Ethernet Shield. Используется, когда IP-адрес был назначен DHCP-сервером. Метод не получает никаких параметров и возвращает объект класса IPAddress.
Метод Ethernet.dnsServerIP() возвращает IP-адрес DNS-сервера. Метод не получает никаких параметров и возвращает объект класса IPAddress.
Метод Ethernet.gatewayIP() возвращает IP-адрес шлюза. Метод не получает никаких параметров и возвращает объект класса IPAddress.
Метод Ethernet.dnsServerIP() возвращает IP-адрес DNS-сервера. Метод не получает никаких параметров и возвращает объект класса IPAddress.
Метода Ethernet.subnetMask() возвращает маску подсети. Метод не получает никаких параметров и возвращает объект класса IPAddress.
Метод Ethernet.maintain() позволяет перепривязать или обновить выданный DHCP-сервером адрес. Метод не получает никаких параметров и возвращает одно из следующих значений типа int:
-
0: ничего не получено;
-
1: обновление неуспешно;
-
2: обновление успешно;
-
3: перепривязка неуспешна;
-
4: перепривязка успешна.
Небольшой пример кода с методами объекта Ethernet:
#include <SPI.h>
#include <Ethernet.h>
byte mac[] = {0x00, 0xAA, 0xBB, 0xCC, 0xDE, 0x02};
void setup() {
Serial.begin(9600);
if (Ethernet.begin(mac) == 0) {
Serial.println("Failed to configure Ethernet using DHCP!");
while (true) {
}
}
Serial.println(Ethernet.localIP());
Serial.println(Ethernet.dnsServerIP());
Serial.println(Ethernet.gatewayIP());
Serial.println(Ethernet.dnsServerIP());
Serial.println(Ethernet.subnetMask());
}
void loop() {
}
Судя по коду библиотеки Ethernet на момент написания этой главы, класс EthernetClass почти класс-одиночка (Singleton). Почти в том смысле, что код класса не является кодом одиночки, но в целом класс ведёт себя как одиночка. Создавать ещё один экземпляр EthernetClass нет смысла, тем более, что установка ещё одного Ethernet Shield не предусмотрена (на шилде нет колодки ICSP/SPI), а код низкого уровня рассчитан только на работу с одним чипом WIZnet W5100.
Смотри также:
[К началу] | [Библиотека Ethernet]
(c) 2015, Симоненко Евгений А. [email protected]