Перейти до основного вмісту

Відправлення email з Qt

Правду кажучи, спочатку у мене нічого не вийшло. Документація в цей раз не допомогла. Форуми теж не дуже були корисні, однак на блозі одного розробника, я знайшов посилання на невеликий проект "SmtpClient-for-Qt". Судячи із записів і вики проект живий, що давало надію.

Не знаю чи можна це назвати бібліотекою, але тим не менш, тут є проста інструкція і приклади. Ще один респект розробникам за простий і зрозумілі код. До всього іншого, бібліотека дозволяє відправляти повідомлення з прикріпленим файлом або в форматі html, що було метою. На жаль, ні в проекті, ні на блозі, через який я знайшов його не було згадки про, я вважаю, одну важливу річь.
Я швидко зібрав додаток, зробив все як написано ... і нічого не вийшло. Вірніше не зовсім вийшло.

В цьому місці потрібно зробити застереження, що я відправляю листи з gmail.com і приймаю також на іншу скриньку google. З інших поштових сервісів не пробував.

Відправлення листа складається з кількох етапів:
  • підключення до сервера
  • вхід в акаунт відправника
  • відправка листа
  • заверщеніе "процедури"
Я завжди, навіть коли пробував робити сам, ловив помилку на "вході в аккаунт" і тут те ж саме. І ось в цьому місці я застряг дуже надовго, перевіряючи паролі, імена, чи включений POP або IMAP і все в такому дусі. Зрештою дійшло і до вдумливого читання документації Google. Виявилося, що двухфакторная аутентифікація успішно блокує всі мої спроби входу і відправляє відповідь "пароль невірний". У підсумку, перше повідомлення вдалося відправити лише після відключення цієї функції і включення дозволу для доступу ненадійних програм.

Посилання:
Блог "От простого к невозможному" - http://blogger.sapronov.me/2013/07/qt-e-mail.html
SmtpClient-for-Qt - https://github.com/bluetiger9/SmtpClient-for-Qt

Коментарі

Популярні дописи з цього блогу

Qt та Excel. Робота з ячейками.

Для доступу до всіх властивостей і вмісту ячійок у Excel використовуються два об'єкти Range і Cells. Між ними є тільки одна відмінність (крім назви) - перший об'єкт забезпечує доступ до області ячійок та його аргументом є строка. QAxObject *myRange; myRange = sheetAct->querySubObject("Range (QVariant)", "A1:D3"); myRange->dynamicCall("Select()"); / / виділяємо діапазон ячійок Cells забезпечує доступ тільки до однієї ячійки і аргументом є номер рядка і стовпця. Таким чином запис виду: QAxObject *myRange; myRange = sheetAct->querySubObject("Range(QVariant)", "A2"); і QAxObject *myCells; myCells = sheetAct->querySubObject("Cells (Int, Int)", 1, 2); є рівнозначною. Щоб визначити реальну адресу ячійки або діапазону ячійок можна скористатися властивістю Address, яке має наступні параметри: RowAbsolute, ColumnAbsolute, ReferenceStyle, External, RelativeTo. myRange = sheetAct->querySubObject(...

QString в HEX и обратно

Спочатку з QString робимо QByteArray. Зауважимо, якщо у вас по тексту тільки латинські букви цілком підійде варіант з .toUtf8(). Якщо ж присутня і кирилиця - обов'язково використовуємо .toLocal8Bit(). QString strA = "Some text"; QByteArray bA = strA.toLocal8Bit().toHex(); Перетворення QByteArray в початковий текст має такий вигляд: QString strB = QString::fromLocal8Bit(QByteArray::fromHex(bA))); Цікаво, що якщо ми для зберігання записали отриманий Нех куди-небудь, наприклад, в файл або базу даних у вигляді текстового рядка, то для зворотного перетворення цей рядок потрібно додатково перетворити в QByteArray. QString strA2 = QString::fromUtf8(bA); QByteArray bB = strA2.toUtf8(); QString strB = QString::fromLocal8Bit(QByteArray::fromHex(bB)));

Qt Округлення до певного розряду

Округлення - тривіальна задача в математиці, але в Qt немає функції округлення до певного розряду. Проте в QtMath є такі функції як qFloor (qreal) і QCeil (qreal), в результаті яких int. А також можна використовуючи round (double), отримати double. Дуже швидко я знайшов ось цей ресурс звідки взяв вихідну формулу. Вона без сумніву працює, але дає результати, які не відповідаю моїм очікуванням: toRound(187.156, 2); //187.15 toRound(187.156, 1); //187.1 toRound(187.156, 0); //187 toRound(187.156, -1); //180 toRound(187.156, -2); //100 Після невеликої корекції самої функції, її підсумковий варіант виглядає так: double wcsv::toRound(double val, int r) {   double outpValue;   double tempVal;   tempVal=val*pow(10,r);   if (double(int(tempVal))+0.5==tempVal){     int(tempVal)%2 == 0       ? outpValue=double(qFloor(tempVal))/pow(10,r)       :outpValue=d...