Об отправке электронных писем средствами платформы "Бухгалтерия предприятия КОРП"

28.03.19

Интеграция - Email рассылки

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

В процессе работы появилась интересная задача. Заказчик дал задание по реализации отправки почтовых сообщений,  причём основным условием было создание печатной формы отчёта о доставки электронных писем.

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

Для отправки сообщений использовалось два пути:

  1. «Почта», с использованием Outlook.

  2. «ИнтернетПочта», то есть встроенные функции 1С.

Первый вариант достаточно прост. Учитывая то, что все учётные записи пользователя, вместе с паролями находятся в приложении Outlook, то остаётся только обратиться к ним из 1С, добавить адресата, сформировать само письмо, если необходимо, то с вложениями, и отправить его.

Процедура ОтправкаПисьма(Кнопка)
	ПредставлениеСохраняемогоФайла = ПолучитьТекстЗаголовка(Ложь);
	Результат = ЭтаФорма.ЭлементыФормы.Результат;
	ПолноеИмяФайла = РаботаСФайлами.УдалитьЗапрещенныеСимволыИмени(ПредставлениеСохраняемогоФайла);
	КаталогВр = КаталогВременныхФайлов(); //Определение каталога временного файла
	Результат.Записать(КаталогВр + ПолноеИмяФайла + ".xls",ТипФайлаТабличногоДокумента.XLS); //Запись таблицы отчёта в файл на диске
	ПолучитьПользователя = ПараметрыСеанса.ТекущийПользователь;
	ЯщикПользователя = Справочники.КД_ЭлектроннаяПочтаСотрудников.НайтиПоНаименованию(ПолучитьПользователя).ПочтовыйПрофиль;
	НовСообщение = Новый ПочтовоеСообщение; //Создание сообщения
	ТекстСообщения = "";
	ПодсказкаСообщ = "Введите текст сообщения.";
	ВвестиСтроку(ТекстСообщения,ПодсказкаСообщ,500,Ложь);
	НовСообщение.Текст = ТекстСообщения;
	НовСообщение.Отправитель = ЯщикПользователя;
	ТекстТема = "";
	ПодсказкаТема = "Введите тему письма.";
	ВвестиСтроку(ТекстТема,ПодсказкаТема,50,Ложь);
	НовСообщение.Тема = ТекстТема;
	ТекстПолучатель = "";
	ПодсказкаПолуч = "Введите имя получателя.";
	ВвестиСтроку(ТекстПолучатель,ПодсказкаПолуч,50,Ложь);
	АдресПолучателя = ТекстПолучатель;
	ЯщикПолучателя = Справочники.КД_ЭлектроннаяПочтаСотрудников.НайтиПоНаименованию(АдресПолучателя).ПочтовыйПрофиль;
	НовСообщение.Получатели.Добавить(ЯщикПолучателя);
	ФайлВложения = КаталогВр + ПолноеИмяФайла + ".xls";
	НовСообщение.Вложения.Добавить(ФайлВложения,ПолучитьТекстЗаголовка(Ложь));	
	Почта = Новый Почта;
	Почта.Подключиться();	
	Попытка
		Почта.Послать(НовСообщение,Истина);
	Исключение
		Сообщить(ОписаниеОшибки());
		Возврат
	КонецПопытки;
	Почта.Отключиться();
КонецПроцедуры

 

Во втором варианте подключение к почтовому ящику без особых условий и запретов получается только на сервисе mail.ru. Yandex и Google не позволяют авторизоваться из-за особенностей протоколов безопасности, проблема решается более тонкой настройкой сервисов (полная справка находится на «саппорте» каждого сервиса).

Упростить работу помогла функция определения сервиса почтового ящика (ведь у пользователя он может быть и не один), функция, помещенная в модуль объекта. Функция определяет почтовый сервис и возвращает значение необходимого профиля почты.

Функция ПолучитьПрофиль(ИмяЯщика,ПочтовыйСервис,ПарольОтЯщика) Экспорт		
		Профиль = Новый ИнтернетПочтовыйПрофиль;		
		Если ПочтовыйСервис = "@mail.ru" Тогда
			Профиль.АдресСервераSMTP = "smtp.mail.ru";			
			Профиль.ПортSMTP = 25;
			Профиль.Пароль = ПарольОтЯщика;
			Профиль.ПарольSMTP = ПарольОтЯщика;
			Профиль.Пользователь = ИмяЯщика + ПочтовыйСервис;
			Профиль.ПользовательSMTP = ИмяЯщика + ПочтовыйСервис;
			Профиль.ВремяОжидания = 60; 
			Возврат Профиль;
		ИначеЕсли  ПочтовыйСервис = "@yandex.ru" Тогда 
			Профиль.АдресСервераSMTP = "smtp.yandex.ru";
			Профиль.ПортSMTP = 465;	
			Профиль.АутентификацияSMTP = СпособSMTPАутентификации.ПоУмолчанию;
			Профиль.ИспользоватьSSLSMTP = Истина;
			Профиль.Пароль = ПарольОтЯщика;
			Профиль.ПарольSMTP = ПарольОтЯщика;
			Профиль.Пользователь = ИмяЯщика + ПочтовыйСервис;
			Профиль.ПользовательSMTP = ИмяЯщика + ПочтовыйСервис;
			Профиль.ВремяОжидания = 60; 
			Возврат Профиль;
		ИначеЕсли ПочтовыйСервис = "@gmail.com" Тогда
			Профиль.АдресСервераSMTP = "smtp.gmail.com";
			Профиль.ПортSMTP = 465;
			Профиль.АутентификацияSMTP = СпособSMTPАутентификации.ПоУмолчанию;
			Профиль.ИспользоватьSSLSMTP = Истина;
			Профиль.Пароль = ПарольОтЯщика;
			Профиль.ПарольSMTP = ПарольОтЯщика;
			Профиль.Пользователь = ИмяЯщика + ПочтовыйСервис;
			Профиль.ПользовательSMTP = ИмяЯщика + ПочтовыйСервис;
			Профиль.ВремяОжидания = 60; 
			Возврат Профиль; 			
		КонецЕсли;		
	КонецФункции

Затем следует процедура формирования и отправки письма.

Процедура ДействияФормыОсновныеОтправить(Кнопка)
	
	ПредставлениеСохраняемогоФайла = ПолучитьТекстЗаголовка(Ложь);
	Результат = ЭтаФорма.ЭлементыФормы.Результат;
	ПолноеИмяФайла = РаботаСФайлами.УдалитьЗапрещенныеСимволыИмени(ПредставлениеСохраняемогоФайла);
	КаталогВр = КаталогВременныхФайлов();
	Результат.Записать(КаталогВр + ПолноеИмяФайла + ".xls",ТипФайлаТабличногоДокумента.XLS);
	ПолучитьПользователя = ПараметрыСеанса.ТекущийПользователь;
	Запрос = Новый Запрос;
	Запрос.Текст = "Выбрать Представление
	|ИЗ РегистрСведений.КонтактнаяИнформация
	|Где Объект = &ПП";
	Запрос.УстановитьПараметр("ПП",ПолучитьПользователя);
	РЗ = Запрос.Выполнить().Выгрузить();
	Для каждого Стр Из РЗ Цикл
		ПочтЯщ = Стр.Представление;	
	КонецЦикла;
	ПрофильПочты = ПолучитьПрофильПочты(ПочтЯщ);
	СервисПочты = ПолучитьСервисПочты(ПочтЯщ);
	ЯщикПользователя = ПрофильПочты + СервисПочты;
	ПарольОтЯщика = "";
	ПодсказкаПароля = "Введите пароль от своего почтового ящика!";
	ВвестиСтроку(ПарольОтЯщика,ПодсказкаПароля,15,Ложь);
	Если ПарольОтЯщика = "" Тогда
		Сообщить("Без пароля не получится!");
		Возврат;
	КонецЕсли;
	///////Подключение к почте///////
	Почта = Новый ИнтернетПочта;
	Попытка
		Почта.Подключиться(ПолучитьПрофиль(ПрофильПочты,СервисПочты,ПарольОтЯщика));
		Письмо = Новый ИнтернетПочтовоеСообщение;
		Письмо.Вложения.Добавить(КаталогВр + ПолноеИмяФайла + ".xls",ПолучитьТекстЗаголовка(Ложь));
		Письмо.Отправитель = ЯщикПользователя;
		Письмо.ИмяОтправителя = ПолучитьПользователя;
		ПочтовыеАдреса = Письмо.Получатели;
		ПочтовыйАдрес = ПочтовыеАдреса.Добавить();
		ВозврЗначАдресат = Справочники.Пользователи.ПолучитьФормуВыбора("ФормаВыбора",ЭтаФорма).ОткрытьМодально();//Получение адресата из списка пользователей
		Если ВозврЗначАдресат = "" Тогда
			Сообщить("Не заполнено ФИО адресата! Попробуйте ещё раз!");
			Возврат;
		Иначе
			Запрос = Новый Запрос;        //Получение почтового ящика из регистра сведений
			Запрос.Текст = "Выбрать Представление КАК Ящик
			|ИЗ РегистрСведений.КонтактнаяИнформация
			|Где Объект.Наименование = &ПП";
			Запрос.УстановитьПараметр("ПП",ВозврЗначАдресат.Наименование);
			РЕЗ = Запрос.Выполнить().Выгрузить();
			Для каждого Стр Из РЕЗ Цикл
				ЯщикАдр = Стр.Ящик;	
			КонецЦикла;
			ПрофильАдресата = ПолучитьПрофильПочты(ЯщикАдр);
			СервисАдресата =  ПолучитьСервисПочты(ЯщикАдр);
			ПочтаАдресата =  ПрофильАдресата + СервисАдресата;
			ПочтовыйАдрес.Адрес = ПочтаАдресата;
		КонецЕсли;
		Письмо.Тема = "";
		ПодсказкаТемы = "Обозначьте тему письма! (Не обязательно)";
		ВвестиСтроку(Письмо.Тема,ПодсказкаТемы,50,Ложь);
		ИнтернетТекстПочтовогоСообщения = Письмо.Тексты.Добавить();
		ИнтернетТекстПочтовогоСообщения.Текст = "С уважением, " + ПолучитьПользователя + ".";
		ИнтернетТекстПочтовогоСообщения.ТипТекста = ТипТекстаПочтовогоСообщения.ПростойТекст;
		Попытка
			Почта.Послать(Письмо);
			Предупреждение("Ваше письмо успешно отправлено. Хорошего завершения дня!",10);
		Исключение
			Сообщить(ОписаниеОшибки());
			Возврат;
		КонецПопытки;		
	Исключение
		Сообщить("УПС! " + ОписаниеОшибки());
	КонецПопытки;
	Почта.Отключиться();
	///
	РегистрыСведений.АС_ЗадачиПользователя.ПолучитьФормуРедактированияЗаписи(,ЭтаФорма).ОткрытьМодально();//Создание задачи пользователю в планировщике.
КонецПроцедуры

 

Но даже если не плыть против течения и использовать сервис, который даёт беспрепятственный вход в почтовый ящик (mail.ru, к примеру), то после отправки письма адресату возникает вопрос - "как программно задать получение отчета о прочтении?". Ответом оказалось "Никак". Даже в самом почтовом ящике Mail.ru кнопка, включающая оповещение о доставке письма не активна, то есть при нажатии на неё не происходит абсолютно ничего, письмо отправляется, но отчёт о его доставке не приходит (программно, что естественно, тоже не включается).

Тогда был опробован первый вариант. С помощью Outlook отправлялись сообщения как с сервиса Mail.ru на Yandex и Google, так и обратно. Даже при установке в настройках Outlook флажка о доставке отчёта о доставке и прочтении не происходило ничего.

Выводы.

В процессе поисков решений было выяснено, что на почтовых сервисах, не известно с какого времени (это касается всех почтовых сервисов, описанных выше), была встроена функция, позволяющая пользователю, получающему письмо, не отправлять отчёт о доставке и прочтении. Так, к примеру, на Yandex.ru, при получении письма появляется кнопка, при нажатии которой отправляется отчёт о том, что письмо доставлено, если её не нажимать, то, естественно, отчёт о доставке отправлен не будет, и неважно - сколько потратил времени программист на то, чтобы программно задать запрос проверки доставки письма.

На Gmail.com сделано ещё интересней, конечно же отчёт можно по желанию не отправлять, но разработчики добавили функцию игнорирования письма, при активизации которой полученное письмо просто "испаряется" из почтового ящика, как будто его там и не было.

Ну а Mail.ru просто не отправляют отчёт о доставке и всё.

Из всего вышесказанного следует:

- настроить отправку почты из 1С возможно и не находится за гранью недосягаемого;

- программная установка запроса на подтверждение доставки и прочтения электронного письма не имеет никакого смысла.

Почта интернет-почта почтовый сервис отчет доставка

См. также

Взаиморасчеты Email рассылки Акт сверки Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Платные (руб)

Внешняя обработка для Бухгалтерии 3.0 - позволяет автоматически формировать документы «Акт сверки расчетов» с контрагентами за выбранный период с последующей фоновой отправкой на почту контрагента.

3000 руб.

25.11.2020    24998    257    8    

221

Взаиморасчеты Email рассылки Акт сверки Бухгалтер Пользователь Платформа 1С v8.3 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Создать и отправить 1000 Актов серки контрагентам за 5 мин ?! Легко! Разработано для конфигурации УНФ Массовое создание и рассылка Актов сверки в три клика.

6000 руб.

13.01.2022    10915    8    13    

13

Email рассылки Программист Пользователь Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Решение для массовой рассылки печатных форм (в том числе и дополнительных) любых документов, и произвольных файлов. Рассылка возможна посредством электронной почты, Telegram и файловой системы. Рассылка пакета документов. Добавление факсимильных печати и подписи. Произвольные шаблоны HTML/Simple text с автозаполнением любыми полями документа. Любые форматы файлов. Упаковка вложений в архив. Транслитерация имен файлов. Разбиение рассылки на произвольные порции. Обход спам-фильтров. Журналирование рассылок.

4920 руб.

30.06.2022    11350    73    98    

35

Взаиморасчеты Email рассылки Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Платные (руб)

Обработка позволяет автоматически сформировать акты сверок на почту контрагентов (почта берется из контактных данных контрагента). При формировании акта сверки формируется подпись с указанием контактов для связи с бухгалтерией нашей организации (формируется исходя из контактов из карточки организации). Присутствует возможность ручного редактирования электронной почты контрагента для отправки. Отправка осуществляется с системной записи электронной почты. В случае, если у контрагента нет адреса электронной почты, эти контрагенты будут выведены в отдельной табличной части. Это очень удобно, так как сразу наглядно виден список контрагентов, которым невозможно отправить акты сверок!

7080 руб.

11.05.2021    9729    6    1    

6

Email рассылки Взаиморасчеты Акт сверки Бухгалтер Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Обработка для конфигурации Управление торговлей 10.3 (КА 1.1, УПП 1.3), которая автоматически формирует акты сверок взаиморасчетов, позволяет их скопом распечатать и разослать по электронной почте контрагентам.

2160 руб.

08.02.2018    31602    47    0    

54
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mart-sha 296 14.11.24 22:39 Сейчас в теме
в 2024 году ничего не поменялось в части получения ответа как ушло письмо ? Например неправильный адрес.
Оставьте свое сообщение