1С:Деньги - Автоматическое заполнение расходов по QR-кодам чеков с помощью API ФНС

09.07.24

Интеграция - ЭДО и ОФД

UPDATE 2020.11 Учтено новое API взаимодействия с серверами проверки чеков ФНС. Реализована верификация по номеру телефона и кода из SMS. Обработка поможет сократить время на ввод данных о расходах в 1С:Деньги. Достаточно отсканировать QR-код чека смартфоном, с предустановленным официальным приложением проверки чеков от ФНС. Данные чека будут загружены в базу из данных электронного чека, которые хранятся на серверах ФНС. Обработка протестирована на последнем релизе 2.0.44.28.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование SM По подписке [?] Купить один файл
Загрузить Чеки с ФНС
.epf 19,69Kb
23
23
1 SM
Скачать Купить за 1 850 руб.
Загрузить Чеки с ФНС. Версия 3. Автоматическая загрузка по новому API
.epf 26,39Kb
66
66
2 SM
Скачать Купить за 2 150 руб.
Загрузить Чеки с ФНС. Версия 2 через json
.epf 20,90Kb
13
13
1 SM
Скачать Купить за 1 850 руб.

1. Устанавливаем себе на мобильное устройство программу "Проверка чеков" с PlayMarket или AppStore.
2. Регистрируемся с помощью данной обработки на вкладке "Настройка" - раздел "Регистрация", либо официального приложения, на официальном сервере проверки чеков ФНС - указываем доступный номер телефона. Жмем зарегистрироваться. Получаем SMS с кодом подтверждения.


3. Заносим номер телефона в формате +79XXXXXXXXX и полученный через SMS код в соответствующие поля на вкладке "Настройки" - раздел "Верификация". Проходим верификацию, получаем session id и токен обновления сеанса соединения (по умолчанию время жизни сеанса - 24 часа)


4. При получении чека в магазине сканируем его QR-код программой "Проверка чеков".


5. В данной обработке на вкладке "Чеки" выбираем период запроса, по умолчанию установлено "Сегодня".

6. Нажимаем кнопку "Загрузить чеки". Список подгружается с сайта налоговой.


7. Выбираем строку интересующего чека в загруженной таблице чеков.
8. Переходим на вкладку "Текущий чек". Указываем кошелек расхода. Также проверяем/правим статьи расхода.  Нажимаем кнопку "Перенести в документ". Автоматически создается/перезаполняется документ расхода.

 

Обработка создана по мотивам разработки форума программы 1С:Деньги в контексте облегченной версии.

 

UPDATE 2020.07. ВЕРСИЯ 2 ЧЕРЕЗ JSON

Всвязи с последним обновлением официального приложения проверки чеков ФНС, логика работы и актуальные адреса серверов проверки чеков были изменены разработчиками. Все "старые" чеки - до момента обновления приложения - будут загружаться по прежнему.

На текущий момент есть возможность выгружать чеки из приложения в JSON

например на почту

и загружать далее данные из файла в обработку.

В обновленную версию обработки добавлена возможность загружать данные чеков из файла выгрузки *json.

 

UPDATE 2020.11. ВЕРСИЯ 3 НОВОЕ API

Благодаря данной и данной разработкам, также источникам, на которые ссылаются данные разработки, удалось проработать взаимодействие с серверами ФНС по новому API_v2 и вернуться к возможности прямой автоматической загрузки чеков. Таким образом логика работы обработки не изменилась. Возможность ручной загрузки чеков из файлов выгрузок в формате JSON сохранена.

Основное отличие текущей обработки от существующих аналогов на текущий момент, заключается в том, что реализована возможность авторизации по номеру телефона и SMS. 

Проверено на следующих конфигурациях и релизах:

  • 1С:Деньги, релизы 2.0.44.40, 2.0.44.28, 2.0.43.36, 2.0.43.20, 2.0.42.30, 2.0.42.20, 2.0.41.34, 2.0.41.26, 2.0.40.12

обработка загрузка 1С:Деньги чеки ФНС

См. также

SALE! 50%

Кассовые операции Файловый обмен (TXT, XML, DBF), FTP ЭДО и ОФД Программист Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Бухгалтерский учет Налоговый учет Управленческий учет Платные (руб)

В публикации размещены специализированные обработки для загрузки кассовых чеков в базах 1С (для локальных баз): '1С:Бухгалтерия предприятия, ред. 3.0', '1С:Управление нашей фирмой 8, ред. 3.0', '1С:Комплексная автоматизация, ред. 2.5', ‘1С:ERP Управление предприятием, ред. 2’ и ‘1С:Управление торговлей, ред. 11.5’. Вы просто сканируете QR коды с бумажных и электронных чеков c помощью мобильного приложения ФНС и чеки автоматически (без ручного ввода) загружаются в документы 'Авансовый отчет', 'Расходы предпринимателя', 'Путевой лист', 'Приходная накладная', 'Поступление (акты, накладные, УПД)', 'Приобретение товаров и услуг', 'Отчет о розничных продажах' и 'Поступление денежных документов'.

12960 9720 руб.

19.08.2020    66857    320    73    

215

Регламентированный учет и отчетность ЭДО и ОФД Бухгалтер Платформа 1С v8.3 1С:Бухгалтерия 3.0 Пищевая промышленность Россия Бухгалтерский учет Налоговый учет Акцизы Платные (руб)

Расширение для Бухгалтерии предприятия 3.0 «Акцизы на сахаросодержащие напитки» предназначено для автоматизированного учета сумм акцизов по реализованным сахаросодержащим напиткам с 01 июля 2023 года. Позволяет выделить суммы акциза в первичных документах («Реализация товаров и услуг», «Корректировка реализации»), сформировать проводки по начислению акциза, а также сформировать и отправить корректные документы по ЭДО.

14400 руб.

16.10.2023    1551    14    0    

13

Регламентированный учет и отчетность Обмен с ГосИС ЭДО и ОФД Бухгалтер Пользователь Платформа 1С v8.3 1С:Управление торговлей 11 Оптовая торговля, дистрибуция, логистика Россия Управленческий учет Платные (руб)

Работаете по контрактной схеме, сталкивались с проблемой, что в контракте жестко указаны наименование, цена, единица измерения товара. И не все готовы создавать новую номенклатуру под каждый контракт или менять наименование и единицу измерения для уже имеющейся. Тем более, бывает так, что контракт - это формальность. Контракт не описывает жесткие условия поставки, нужно соблюсти правильность в предоставлении документов. Данное решение позволит вам оперировать своей номенклатурой при оформлении реализаций по государственному контракту в УТ 11.5 и КА 2.5.11, в то же время выводить на печать документы, соответствующие данным контракта. Реализована выгрузка для сайта госзакупок (ЕИС) по 44-ФЗ.

40800 руб.

19.12.2022    10943    24    19    

17

Документооборот и делопроизводство (СЭД) ЭДО и ОФД Учет документов Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Мощный, единый инструмент для решения всех проблем, связанных с переходом на ЭДО. Экономит бумагу и время - организует архив оригиналов первичных документов прямо в базе 1С, в прикрепленных файлах к соответствующим документам. С помощью комплексного отчета по ошибкам в ЭДО позволяет выявить и исправить все возможные ошибки - ошибочно сопоставленные документы, не подписанные документы, подписанные, но не загруженные в 1С документы. Автоматически сопоставляет не сопоставленные между собой документы. Может работать по расписанию и присылать отчет о состоянии архива/по ошибкам на почту. Взаимодействует напрямую с сервисами Диадок/СБИС, имеет интуитивно понятный интерфейс и учитывает 3-х летний опыт 40+ клиентов.

14880 руб.

17.12.2018    45030    63    51    

76

Кассовые операции ЭДО и ОФД Бухгалтер Платформа 1С v8.3 Бухгалтерский учет 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Комплексная автоматизация 2.х Россия Бухгалтерский учет Платные (руб)

Согласно 54-ФЗ по правилам ведения кассовых операций необходимо оформлять приходные кассовые ордера (ПКО) и расходные кассовые ордера (РКО) на основании чеков ККМ. Все данные о чеках, можно взять на сайте оператора фискальных данных (ОФД). Обработка загрузки данных из ОФД в 1С сделает за вас в 1С - ПКО и РКО, Операции по платежным картам или Отчет о розничных продажах (может создать номенклатуру в 1С, указать налоги и др. реквизиты в документах в зависимости от налогообложения ККМ в торговой точке). Проверено на: OFD.RU / Первый ОФД / Такском / Платформа ОФД / Ярус / ОФД Яндекс / ОФД Астрал /ОФД СБИС / Гарант ОФД / КОРУС ОФД / КОНТУР ОФД / ОФД АО Тандер / ИнитПро / Группа Элемент/

3600 руб.

09.08.2017    149658    881    372    

534

ЭДО и ОФД Обмен с ГосИС Программист Бухгалтер Пользователь 8.3.14 1С:Управление торговлей 10 1С:Розница 2 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление холдингом 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Рабочее место для работы с ЭДО из 1С : Диадок, СБИС, ЭДО Лайт (Lite), Такском, Signatura.pro, Астрал.ЭДО, ГИС МТ (Честный знак, ЦРПТ). Загрузка и отправка УПД, УКД, ТОРГ12, Акта в 1С (сохранение в файл и последующая загрузка через личный кабинет не требуется). Также поддерживается: отправка печатных форм, произвольных файлов, подписание, отклонение, аннулирование документов. Поддержка МЧД для СБИС и Диадок. Решение реализовано в виде расширения на управляемых формах. Для обычных форм - внешняя обработка. Поддержка Linux.

3600 руб.

16.12.2020    39103    248    199    

89
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Dinochka 13 30.06.20 06:56 Сейчас в теме
Здравствуйте.
Скачал Вашу обработку. Чеки не загружаются. В настройках ответ сервера []. В чем может быть проблема?
В приложении "Проверка чеков" чек загружен.
Deniskinr83; +1 Ответить
2. 1sig 248 30.06.20 10:40 Сейчас в теме
(1) Добрый день! Если ответ пустой, значит нет связи с серверами ФНС, телефон/пароль указали в обработке? те, которые были получены при регистрации в "Проверке чеков".
3. Dinochka 13 30.06.20 11:00 Сейчас в теме
(2) Телефон и пароль указал. Проверил соединение. В ответе получил "email" и "name" (заполненные).
4. 1sig 248 30.06.20 14:25 Сейчас в теме
(3) ок, связь с серверами ФНС значит есть, а поле период запроса устанавливаете?
5. Dinochka 13 30.06.20 17:25 Сейчас в теме
(4) да. этот месяц, либо неделя, либо конкретные даты (с по)
6. 1sig 248 01.07.20 06:01 Сейчас в теме
(5) обычно если чеки успешно отсканированы по QR и определены в мобильном приложении "Проверка чеков", они подтягиваются и в данную обработку, естественно при авторизации на один и тот же аккаунт в приложении и данной обработке. При этом поле период запроса должен включать даты загруженных чеков, если на данную дату/период выборки нет чеков, будет возвращаться пустой ответ сервера [], как в вашем случае.
7. info1i 230 22.07.20 18:55 Сейчас в теме
В обработке реализована загрузка с сайта ФНС и с диска.
Я же бэкаплю свои чеки в почте, загрузка из почты: моя разработка.
Также привожу примеры по предварительной настройке базы, чтобы автоматически заполнялись поля "Кошелек", "Контакт", "Статья расхода".
8. d.tsoy 25.07.20 14:08 Сейчас в теме
Здравствуйте.

Скачал обработку "Загрузить Чеки с ФНС. Версия 2 через json". Из мобильного приложения отправил себе на почту выгруженный чеки в формате json. Файл с почты сохранил на компьютере и загружаю его в Вашей обработке. В результате получаю ошибку, отображенную в прикрепленном файле. Подскажите, пожалуйста, как исправить ошибку?
Прикрепленные файлы:
9. 1sig 248 25.07.20 18:35 Сейчас в теме
(8) добрый день! интересная ошибка, с помощью данной обработки уже было прогружено порядка 15 различных чеков из различных торговых точек, такой ошибки не наблюдалось, скинете пример json файла вашей выгрузки? чеки выгружаете с последней версии офиц. приложения проверки чеков ФНС?
10. d.tsoy 25.07.20 20:05 Сейчас в теме
(9) Пример файла json во вложении. В нем несколько чеков. Приложение последней официальной версии. Такая ошибка наблюдается при выгрузке файла через функцию отправки файла на почту непосредственно возможностями приложения. Если скачивать файл json используя функционал ОС Android, то такой ошибки не возникает. Сильно не вникал в предоставленный Вами алгоритм, но пока помогло вот такое условие в процедуре "ЗагрузитьИзФайлаНаСервере":

Если Чек.Свойство("ticket") Тогда
        ПолныйЧек = Чек.ticket.document.receipt;
	СтрокаЧеков = Объект.Чеки.Добавить();
	СтрокаЧеков.Дата = ПолучитьДату(ПолныйЧек.dateTime);
Иначе
        //исходный алгоритм
	ПолныйЧек = Чек;
	СтрокаЧеков = Объект.Чеки.Добавить();
	СтрокаЧеков.Дата = Дата(1970,1,1,1,0,0) + ПолныйЧек.dateTime;
КонецЕсли;

И аналогичное условие в процедуре "ЗагрузитьВыделенныйЧекСервер":

	Если ОбъектЧек.Свойство("ticket") Тогда
		ТекЧек = ОбъектЧек.ticket.document.receipt;	
		СтрокаТекЧек.Дата = ПолучитьДату(ТекЧек.dateTime);
	Иначе
		//исходный алгоритм
	       Если ТипЗНЧ(ОбъектЧек) = Тип("Структура") Тогда
			ТекЧек = ОбъектЧек;
			СтрокаТекЧек.Дата = Дата(1970,1,1,1,0,0) + ТекЧек.dateTime;
		Иначе
			ТекЧек = ОбъектЧек.document.receipt;
			СтрокаТекЧек.Дата 			= ПолучитьДату(ТекЧек.dateTime);
		КонецЕсли;
         КонецЕсли;
Показать

Полагаю, Вы сможете предложить более подходящее решение, если я учел не все условия.
Прикрепленные файлы:
extract_22-07-2020_25-07-2020.json
11. 1sig 248 25.07.20 20:56 Сейчас в теме
(10) все верно сделали.
Вообще изначально использовался алгоритм через Чек.ticket.document.receipt - в те добрые времена, когда можно было json тела чека вытягивать напрямую из серверов ФНС. Но похоже те добрые времена закончились, теперь чтобы получить авторизационный токен к открытому API офиц. сервиса проверки чеков ФНС - нужно заключать с ФНС соглашение от имени юр. лица, для типовых пользователей физлиц они такой доступ не дают.
Поэтому вот остается пока что только обрабатывать данные файла json, полученного выгрузкой из новой версии приложения проверки чеков. Изначально, json получался как раз через средства ОС Android, далее по мере анализа новой структуры данных, выяснилось - начались расхождения в данных, вызывающие исключит. ситуации, пришлось переписать немного код разбора полей тела чека.
Спасибо за обратную связь! Особенно про функцию прямой отправки чеков на почту, алгоритм обработки будет изменен с учетом этого в ближайшее время.
12. пользователь 17.08.20 05:56
Сообщение было скрыто модератором.
...
13. user1450771 17.08.20 06:11 Сейчас в теме
Приветствую, коллеги.
Столкнулись с недавним изменением api налоговой. В качестве альтернативы перешли на "онлайн сервис проверка чека" (сайт легко гуглица по наименованию). Есть свое api, предоставляется по обращению. Сервис распознает QR-коды. Пока распознали и вернули все запрашиваемые чеки. Можно рассматривать, как вариант.
14. 1sig 248 17.08.20 09:45 Сейчас в теме
(13)
Добрый день! спасибо за актуальную новость, потестим сервис.
15. delta 679 29.10.20 05:07 Сейчас в теме
(11) Здравствуйте.
Наш с вами коллега сделал возможным прямое получение чеков с портала ФНС https://infostart.ru/public/602254/.
Или можете посмотреть мои примеры реализации прямого обращение к данным ФНС вот здесь https://infostart.ru/public/654300/ и вот здесь https://infostart.ru/public/1277044/ (при наличии логина и пароля от личного кабинета налогоплательщика).
16. 1sig 248 02.11.20 23:03 Сейчас в теме
(15) Добрый день! Спасибо за наводки, в 3-й версии обработки удалось реализовать получение session id с помощью номера телефона и кода из смс.
17. delta 679 03.11.20 03:05 Сейчас в теме
(16) Здравствуйте! Отлично! Рад, что материалы помогли.
18. Kaavan 96 05.11.20 03:13 Сейчас в теме
Хорошая работа, спасибо!
21. 1sig 248 05.11.20 09:10 Сейчас в теме
19. Kaavan 96 05.11.20 03:20 Сейчас в теме
От себя добавил только галку "Только новые", чтобы не загружать в список обработанные чеки за период
20. Kaavan 96 05.11.20 03:24 Сейчас в теме
(19)
	
Объект.Чеки.Очистить();
	
Если ТолькоНовые Тогда
	Для каждого СтрокаТЗ Из Чеки.НайтиСтроки(Новый Структура("ДокументРасхода", Документы.Расход.ПустаяСсылка())) Цикл
		ЗаполнитьЗначенияСвойств(Объект.Чеки.Добавить(),СтрокаТЗ);
	КонецЦикла;
Иначе
	Объект.Чеки.Загрузить(Чеки);
КонецЕсли;
Показать
22. Kaavan 96 13.11.20 04:59 Сейчас в теме
Мне кажется, или API снова перестал работать?
26. 1sig 248 13.11.20 21:55 Сейчас в теме
(22)
по API ошибок нет, а вот отсканированные чеки сервис ФНС со вчерашнего дня стал проверять более 24ч, официальная информация на текущий день такая
Прикрепленные файлы:
23. Kaavan 96 13.11.20 05:03 Сейчас в теме
498 Неверный токен
Код указывает на просроченный или недействительный токен по иным причинам.
25. 1sig 248 13.11.20 08:58 Сейчас в теме
(23)
не воспроизвелась ошибка, обычно по происшествию суток, достаточно обновить сессию с помощью refresh token, будет получен новый session id
24. Kaavan 96 13.11.20 05:06 Сейчас в теме
Помогла повторная авторизация в приложении с получением нового кода. Но чеки в самом приложении так и не получены со вчерашнего дня
27. delta 679 24.11.20 16:35 Сейчас в теме
(23) Иногда такая ситуация может возникать в случае, когда вы одновременно используете один и тот же логин и пароль в разных местах - в этом случае необходимо следовать принципу "эстафетной палочки" - где в последний раз обновляли refresh token, там и текущая версия session id. Их (session id и refresh token) можно скопировать из "последнего" места использования обработки и вставить в "нужном" месте использования обработки и уже там обновить сессию. В таком случае вам не потребуется повторная авторизация в приложении с получением нового кода.
28. SeiOkami 3483 02.01.21 19:16 Сейчас в теме
Ошибка при попытке пройти верификацию

Ошибка: {ВнешняяОбработка.ЗагрузитьЧекиСФНС.Форма.Форма.Форма(227)}: Ошибка при вызове метода контекста (ПрочитатьJSON): Недопустимое состояние потока записи JSON
(Ошибка 422) Не удалось обработать запрос


Ввёл номер телефона и какой-то старый код из СМС. Так и не понял, как при помощи обработки запросить этот код. Если ввести номер телефона, то ругается:

Необходимо указать номер телефона, код из SMS!
29. SeiOkami 3483 02.01.21 19:21 Сейчас в теме
(28) при этом, если ввести совсем рандомный код, то обработка выдаёт ошибку.


Ошибка: {ВнешняяОбработка.ЗагрузитьЧекиСФНС.Форма.Форма.Форма(227)}: Ошибка при вызове метода контекста (ПрочитатьJSON): Непредвиденный символ при чтении JSON


Но ответ сервера при этом вполне понятный: "Incorrect code". Просто не JSON.
30. 1sig 248 05.01.21 14:55 Сейчас в теме
(28)

Добрый день!

Вкладка "Регистрация" - нужно заполнить номер телефона в формате +7... и нажать "Зарегистрироваться", вернется ответ "Пользователь успешно создан" и от KKT.NALOG придет смс для верификации,
далее соответственно вкладка "Верификация" - нужно указать этот же номер телефона и полученный код из смс, нажать кнопку "Пройти верификацию",
если все сделано правильно, придет ответ с Session Id ("живет" сутки) и Refresh token - для обновления сессии.
31. CepeLLlka 71 29.12.23 10:01 Сейчас в теме
Добрый день. Подскажите пожалуйста.

А значение ключа "client_secret" используемый при авторизации в вашей разработке, это какой-то ваш личный идентификатор? Насколько я понял его чтобы получить, нужно подать заявку от юр. лица или от ИП(https://data.nalog.ru/html/sites/www.kkt-online.nalog.ru/api-description/applKKT_OpenAPI.PDF).

Вы его как-то для себя сами получали или это какой-то публичный идентификатор?
32. alexey0702 16.04.24 10:23 Сейчас в теме
Здравствуйте. При попытке установить обработку через Дополнительные обработки выдало ошибку
Невозможно подключить дополнительную обработку из файла.
Возможно, она не подходит для этой версии программы.

Техническая информация:
Метод объекта не обнаружен (СведенияОВнешнейОбработке)
Через Файл-Открыть работает.
Подскажите, пожалуйста, вашу обработку всегда только открывать через файл возможно? Или это в 1С:Деньги так криво реализованы внешние обработки?
Student1C; +1 Ответить
33. Student1C 58 02.07.24 09:01 Сейчас в теме
Поддерживаю. Добавьте требуемый метод.
35. 1sig 248 09.07.24 12:02 Сейчас в теме
(33) добавлено :) если что можете сами по комменту выше
34. 1sig 248 09.07.24 12:00 Сейчас в теме
(32) добрый день, спасибо за обратную связь! Только сейчас увидел ваш комментарий, в 1С:Деньги все норм, нужно включить в конфигурации использование доп обработок и добавить в модуль обработки код инициализации доп обработки, вот хорошие заготовки для копипаста https://infostart.ru/1c/articles/337144/ - п.2
Оставьте свое сообщение