Arduino:Библиотеки/GSM/Класс GSMClient/read()
Материал из Онлайн справочника
Содержание | Знакомство с Arduino | Продукты | Основы | Справочник языка Arduino | Примеры | Библиотеки | Хакинг | Изменения | Сравнение языков Arduino и Processing |
Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.
Функция read()[1]
Считывает следующий байт, пришедший от сервера, к которому подключен клиент (после последнего вызова read()).
Функция read() наследует у класса Stream.
Синтаксис
client.read()
Параметры
Нет.
Что возвращает
Следующий байт (символ). Если данных, доступных для считывания нет, то возвращает значение «-1». Тип данных – int.
Пример
/*
Веб-клиент
Этот скетч при помощи GSM-модуля подключается к вебсайту. Если
точнее, он загружает URL «http://arduino.cc» и отображает его
через монитор порта.
Цепь:
* GSM-модуль, подключенный к Arduino
* SIM-карта с активным тарифным планом
Создан 8 марта 2012 года Томом Иго (Tom Igoe)
http://arduino.cc/en/Tutorial/GSMExamplesWebClient
*/
// библиотеки:
#include <GSM.h>
// PIN-код:
#define PINNUMBER ""
// Данные об APN:
#define GPRS_APN "GPRS_APN" // замените на свой APN
#define GPRS_LOGIN "login" // замените на свой логин к APN
#define GPRS_PASSWORD "password" // замените на свой пароль к APN
// инициализируем экземпляр библиотеки:
GSMClient client;
GPRS gprs;
GSM gsmAccess;
// URL, путь и порт (к примеру, «arduino.cc»):
char server[] = "arduino.cc";
char path[] = "/";
int port = 80; // порт 80 – это дефолтный порт для HTTP
void setup()
{
// инициализируем последовательную коммуникацию:
Serial.begin(9600);
Serial.println("Starting Arduino web client."); // "Запуск веб-клиента Arduino."
// состояние соединения:
boolean notConnected = true;
// запустив модем функцией GSM.begin(),
// подключаем модуль к GPRS-сети при помощи APN, логина и пароля:
while(notConnected)
{
if((gsmAccess.begin(PINNUMBER)==GSM_READY) &
(gprs.attachGPRS(GPRS_APN, GPRS_LOGIN, GPRS_PASSWORD)==GPRS_READY))
notConnected = false;
else
{
Serial.println("Not connected"); // "Соединение не удалось"
delay(1000);
}
}
Serial.println("connecting..."); // "подключение..."
// если подключение прошло успешно, сообщаем через монитор порта:
if (client.connect(server, port))
{
Serial.println("connected"); // "соединение установлено"
// делаем HTTP-запрос:
client.print("GET ");
client.print(path);
client.println(" HTTP/1.0");
client.println();
}
else
{
// если подключиться к серверу не удалось:
Serial.println("connection failed"); // "Соединение не удалось"
}
}
void loop()
{
// если у сервера есть какие-нибудь байты для считывания,
// считываем их и показываем через монитор порта:
if (client.available())
{
char c = client.read();
Serial.print(c);
}
// если сервер отключился, останавливаем работу клиента:
if (!client.available() && !client.connected())
{
Serial.println();
Serial.println("disconnecting."); // "отключение."
client.stop();
// вечно ничего не делаем:
for(;;)
;
}
}
См.также
- ready()
- connect()
- beginWrite()
- write()
- endWrite()
- connected()
- read()
- available()
- peek()
- flush()
- stop()
Внешние ссылки
развернутьПартнерские ресурсы |
---|
развернутьСправочник языка Arduino |
---|
развернутьБиблиотеки Arduino |
---|
развернутьArduino продукты |
---|
развернутьПримеры Arduino |
---|
Категории:
- Страницы, использующие повторяющиеся аргументы в вызовах шаблонов
- Справочник языка Arduino
- Arduino
- Перевод от Сubewriter
- Проверка:myagkij
- Оформление:myagkij
- Редактирование:myagkij
- Страницы, где используется шаблон "Навигационная таблица/Телепорт"
- Страницы с телепортом
- Стандартные библиотеки
- Стандартная библиотека
- Стандартная библиотека Arduino
- Стандартные библиотеки Arduino