PHP Скрипт отложенной рассылки писем.
Очень часто возникает потребность организовать на сайте массовую рассылку писем, например новости сайта для нескольких тысяч пользователей. Но в виду ограничений некоторых хостингов(часто шаред хостинг) на кол-во рассылаемых писем в час, в сутки, эта задача становится не такой уж и простой. Хостеры просто режут все письма превышающие этот лимит и не рассылают адресатам, оно и понятно, борьба со спамерами. Ведь небольшому сайтику незачем рассылать тысячи писем в час, а большой может вполне себе позволить выделенные сервер где нет этих ограничений.
Но, что делать если все-же вам нужно рассылать большое кол-во писем? Для этого есть простое решение, а именно PHP скрипт отложенной рассылки писем. Принцип его работы прост, все рассылаемые письма проходят через него и далее вместо того, чтобы отправится адресату складываются в базу данных. После чего этот скрипт вызывается автоматически через Cron, в заданный интервал времени и рассылает заданное количество писем из базы, за раз. Таким образом не превышая установленных лимитов хостера и добиваясь заданной цели.
Скрипт оформлен в виде класса. Для его работы требуются два дополнительных вспомогательных класса, которые идут с ним в архиве, это:
dbsql.class.php — класс работа с базой данных
mail.class.php — класс для отправки почты
Пример использования скрипта.
include('mail.class.php'); // подключаем класс для отправки почты include('dbsql.class.php'); // подключаем класс работа с базой данных include('mailStec.class.php'); // подключаем наш класс отложенной рассылки // устанавливаем подключение с БД, указав параметры доступа к БД $DB=new DB_Engine('mysql', 'dbHost', 'dbUser', 'dbPass', 'dbName'); // создаем объект для отправки почты $m = new Mail(); $ms = new mailStec (); // инициализация отложенной рассылки $ms->db = $DB; // передаем в отложенную рассылку указатель БД, чтобы скрипт отложенной рассылки мог работать с базой данных, используя методы класса mbsql.class.php $ms->m = $m; // передаем в отложенную рассылку, объект работы с почтой // далее идет непосредственно сама передача письма в очередь на отправку // ставим в очередь письмо $from - от кого(email), $email - email получетеля, $subject - тема письма, $body - текст письма, $priority - приоритет в очереди(от 1 до 10), чем меньше тем первее отправится. $ms->SetStec($from, $email, $subject, $body, $priority); |
Собственно команду $ms->SetStec($from, $email, $subject, $body, $priority); и нужно использовать в любом месте вашего скрипта для отправки письме, вернее для помещения письма в очередь.
Для автоматический рассылки писем, следует настроить крон на запуск скрипта, в котором будет содержаться следующий код
include('mail.class.php'); // подключаем класс для отправки почты include('mbsql.class.php'); // подключаем класс работа с базой данных include('mailStec.class.php'); // подключаем наш класс отложенной рассылки // устанавливаем подключение с БД, указав параметры доступа к БД $DB=new DB_Engine('mysql', 'dbHost', 'dbUser', 'dbPass', 'dbName'); // создаем объект для отправки почты $m = new Mail(); $ms = new mailStec (); // инициализация отложенной рассылки $ms->db = $DB; // передаем в отложенную рассылку указатель БД, чтобы скрипт отложенной рассылки мог работать с базой данных, используя методы класса mbsql.class.php $ms->m = $m; // передаем в отложенную рассылку, объект работы с почтой // Отправить из очереди 50 писем, если не указать кол-во будет отправлено по умолчанию 100 писем из очереди $ms->SendStec(50); |
Для работы скрипта создайте таблицу в базе данных mySQL
CREATE TABLE `stecmail` ( `id` int NOT NULL AUTO_INCREMENT PRIMARY KEY, `from` varchar(100) COLLATE 'utf8_general_ci' NOT NULL, `email` varchar(100) COLLATE 'utf8_general_ci' NOT NULL, `subject` varchar(255) COLLATE 'utf8_general_ci' NOT NULL, `body` text COLLATE 'utf8_general_ci' NOT NULL, `priority` int NOT NULL, `status` int NOT NULL ) COMMENT=''; |
Надеюсь данное решение пригодится вам. Решение достаточно универсально и автономно, можно подключить к любой CMS, любому сайту на любом хостинге. Обширные возможности класса работы с почтой, также позволят гибко настроить работу рассылки, например использовать сторонний SMTP сервер.
Похожие записи
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Интеграция с API ОСАГО сайта sravni.ru
- Комментарии на PHP, Ajax, mySQL
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- Обзор Insurance CMS — платформы для сайтов по страхованию к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Как создать Telegram-бота с авторизацией через сайт к записи
- PHP скрипт: каталог закладок на сайты к записи
- Валидация на PHP к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
Archive
- +2025 (7)
- Февраль 2025 (1)
- Январь 2025 (6)
- +2024 (35)
- Декабрь 2024 (7)
- Ноябрь 2024 (13)
- Октябрь 2024 (8)
- Сентябрь 2024 (1)
- Август 2024 (5)
- Май 2024 (1)
- +2023 (27)
- Ноябрь 2023 (1)
- Октябрь 2023 (13)
- Сентябрь 2023 (10)
- Апрель 2023 (1)
- Март 2023 (1)
- Февраль 2023 (1)
- +2022 (21)
- Декабрь 2022 (11)
- Ноябрь 2022 (1)
- Май 2022 (2)
- Апрель 2022 (2)
- Март 2022 (3)
- Февраль 2022 (1)
- Январь 2022 (1)
- +2021 (17)
- Декабрь 2021 (5)
- Ноябрь 2021 (2)
- Июль 2021 (1)
- Июнь 2021 (2)
- Май 2021 (5)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (36)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (41)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (7)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Подключение к API Пауэр Интернэшнл-шины (ПИШ, 4tochki) 06.02.2025
- Использование API геокодера от LocationIQ на сайте 30.01.2025
- Проверка доступности домена онлайн 29.01.2025
- Форматирование CSS кода 29.01.2025
- Плагин WordPress для настройки robots.txt 13.01.2025