Подписываем и шифруем алкогольные декларации (опт и розница) прямо в 1С 7.7

Подготавливаем (подписываем и шифруем) алкогольные декларации (все формы) прямо в 1С 7.7 (минуя программы-"посредники" типа КриптЭК-Д, КриптоАРМ и т.п.)!

Данная разработка предназначена, в первую очередь, для тех, кто формирует алкогольные декларации непосредственно в 1С. Ведь, после того, как дело сделано и сформирован выходной xml-файл, его нужно подписать и зашифровать, чтобы можно было отправлять на портал гос.органов (ФСРАР и орган субъекта (для розничных деклараций)). Для этого приходится проделывать целую кучу лишних манипуляций с каждым файлом — закачать его в другую программу, нажать кучу кнопок, чтобы в итоге получить готовый к отправке файл. И всё бы ничего, если бы эти программы обеспечивали транспорт до принимающего органа, но, по неким неведомым широкой общественности причинам, алкогольные декларации подаются только через отдельный портал, вручную.

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

Представляемая Вашему вниманию разработка является ответвлением разработки //infostart.ru/public/156416/ с целевой платформой 1С 7.7. Разработка позволяет подготовить файл к передаче прямо в 1С, с удобным минималистическим интерфейсом и сохранением настроек (сертификатов передающей и принимающих сторон), позволяющим подписать и зашифровать файл буквально в два-три клика мыши.

 

Технические детали:

1) Перед подписью файла рекомендую воспользоваться проверкой файла по схеме прямо в этой же обработке, чтобы исключить ошибки.

2) Сохранение настроек (указанных сертификатов декларанта и получателей) сохраняется в разрезе ИНН декларанта (берётся из имени файла) и вида деклараций (розничные/прочие) после каждой их успешного указания. Соответственно, если настройки для конкретного декларанта и типа декларации былы указаны один раз, потом можно сразу жать «Подписать ЭЦП» без выбранной галки «Показывать настройки» — получим подготовку файла к передаче в один клик.

3) Подпись и шифрование реализованы через интерфейс CAPICOM. На компьютере должен быть установлен криптопровайдер, предоставляющий разрешённые ФСРАР ГОСТовские алгоритмы подписи и шифрования (я из таких знаю только КриптоПро CSP, но, вполне возможно, есть и другие, на сайте ФСРАР не нашёл конкретного закрытого перечня разрешённых крпитопровайдеров). При наличии установленного КриптоПро CSP, библиотека CAPICOM должна быть доступна на компьютере, но если по каким-то неведомым причинам её, всё-таки, у Вас нет (что мне кажется весьма маловероятным), её можно скачать по ссылке http://www.microsoft.com/ru-ru/download/details.aspx?id=25281 (вместе с примерами использования).

4) В обработке используется компонента OpenFileDialogsManager.dll для устранения проблемы с «обрезанием» имени файла длиной более 63 символов в диалоге выбора файла.

5) В обработке используется компонента 1CPP.dll версии 3.2.3.20 для подфункции упаковки файла в ZIP-архив. Упаковка в данном способе производится штатным упаковщиком 1С 7.7 — zlibeng.dll. Если у вас уже используется компонента 1CPP.dll более ранних версий ( < 3.2.2.x ) — рекомендую либо обновить её до указанной версии, либо переписать подфункцию упаковки файла УпаковатьФайл() с использованием других средств (например, с использованием компоненты dialmail.dll, или вызовом внешнего упаковщика, например, 7z.exe).

24 Comments

  1. Dolly_EV

    Спасибо!!

    Reply
  2. Dolly_EV

    а xsd в Моксель положить? своим же методом http://infostart.ru/public/115930/ )))

    Reply
  3. andrewks

    (2) чё-то я ленюся… © 🙂

    Reply
  4. sCHTASS

    Что интересная и полезная!

    В догонку предложу сохранить все внешние библиотеки в саму обработку. Было описание технологии, как хранить бинарные файлы в картинках… Вроде как даже тут на инфостарте — надо пошушукать…

    Reply
  5. andrewks

    (4) sCHTASS, см. (2) и (3)

    Reply
  6. sCHTASS

    (5) Сорри, не вникал особливо в предыдущие коменты.

    Reply
  7. Ёпрст

    Нужно только модернизировать — подписать все файлы в папке по шаблону.. и т.д.

    Чтоб не каждый раз выбирать файло, а скопом.

    Reply
  8. andrewks

    (7) Ёпрст, зачем? это же не самостоятельно решение типа КриптЭК-Д, а именно решение для встраивания в конфу на 1С. куда как логичнее встроить этот блок и выполнять прямо при формировании выходного xml-файла (я в своей нетленке сделал так: если выгруженный файл прошёл валидацию, я его сразу же и криптую )

    Reply
  9. Dionisiy

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

    Reply
  10. Угрюмый

    Добрый день! Заинтересовался проблемой проверки сформированной декларации по схеме непосредственно в 1С. Не имея возможности скачать данную обработку (не дорос мой кошелек по $m…), нашел в сети функцию из данной обработки: http://www.forum.mista.ru/topic.php?id=642503 , «воткнул» ее к себе, в результате получаю:

    При проверке по схеме файла D:xmlD6_2920014706_093_06112013_D3C8794C-4F4E-41C3-A8F3-A9CDE21927FE выявлены ошибки!

    OLE.IXMLDOMParseError2

    Но, этот файл в декларанте проверяется без ошибок… Понимаю, что что-то не так, но что?

    Если кто знает в чем проблема, буду очень благодарен!

    Операционка Windows 8; парсер msxml6_x64.msi скачал и установил…

    Reply
  11. andrewks

    (10) какие именно сообщения об ошибках выводятся?

    Reply
  12. Угрюмый

    Выводится только OLE.IXMLDOMParseError2

    Правда функции ВалидацияХМЛпоСхеме() требовались процедуры ВывестиСообщение() и ВывестиОшибкуРазбораХМЛ(), за неимением коих пришлось вставить функцию Сообщить()

    Все от непонимания, с чем работаю… Как я понимаю, validateOnParse — это внутренняя команда mxml, где можно посмотреть ее описание?

    Reply
  13. Угрюмый

    Пардон, разобрался, причина в длинном имени файла (или отсутствии компоненты OpenFileDialogsManager.dll). Но где взять эту самую OpenFileDialogsManager.dll?

    Reply
  14. Угрюмый

    Если не трудно, поясните, пожалуйста:

    При создании xml файла средствами v7plus между тегами нет пробелов и mxml понимает в файле (как и текстовые редакторы/просмотрщики) две строки: «?xml version=»1.0″ encoding=»windows-1251″» и все остальное. Соответственно, и все ошибки получаются во второй строке. Как между тегами поставить пробел или перенос строки

    (как это делает Декларант Алко), чтобы легче было находить ошибки?

    Reply
  15. Bahyt

    Спасибо большое!

    Reply
  16. Bahyt

    (9) Dionisiy

    Куда КОнтур запрятал интерфейс? Я понял так, что это стало теперь платным у них.

    Reply
  17. M_W_W

    Добрый день!

    Подниму старую тему…

    Это вообще сейчас работает? Ничего не поменялось?

    Поясню, почему возник вопрос — решил протестировать, перед тем, как реальные декларации подписывать и отправлять.

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

    Подписываю/шифрую, вроде внешне все выглядит нормально, получаю файл со всеми необходимыми расширениями. Пробую расшифровать его с помощью программы КриптоАРМ, и получаю ошибку — «Не верный формат данных(0x80070057)»… Если тот-же файл зашифровать КриптоАРМом, с тем-же набором сертификатов(личный так-же добавлен в получатели) то он его потом расшифровывает, снимает подпись и сохраняет в исходном виде без проблем…

    Времени с момента публикации разработки прошло много, может что-то изменилось в «свежих» сертификатах или алгоритмах КриптоПРО, что нужно еще какой-либо параметр в процедуру шифрования добавить? Понимаю, что не должно, но все-же… Проверить отправкой реальных файлов в ЛК ФСРАР пока не могу, только на следующей неделе будут реальные декларации готовы…

    Reply
  18. M_W_W

    Программа «Такском-КриптоЛайн» тоже не расшифровывает — пишет «Файл не зашифрован или поврежден».

    Тормознул в отладчике до того, как она удаляет временные файлы, и выяснилось, что уже подпись работает не правильно, не КриптоАРМ не Такском-КриптоЛайн не открывают подписанный файл. В zip упаковывает нормально…

    Reply
  19. M_W_W

    Если открыть подписанный(отловленный до архивирования и шифрования) файл просто блокнотом(Notepad+), то внутри него двоичная «абракадабра», по большей части «NUL»-ами заполнен… Если открыть подписанный КриптоАРМ или КриптоЛайн, то там виден исходный текст XML, только вначале и в конце двоичные фрагменты, видимо «крипто-хвосты» самой подписи.

    Что происходит с файлом при подписании, почему он «портится» — ?

    Пробовал на компьютере с WIN-XP и КриптоПро 3.6, попробовал на Win-7 c VipNet-CSP, результат один и тот-же…

    Reply
  20. M_W_W

    Попробовал сейчас 8-рочную версию обработки, результат тот-же самый…

    Единственное, что работает, и в 7.7 и в 8, это валидация файлов деклараций по схемам. Ну, конечно, схемы пришлось заменить на актуальные, в 7.7 в каталоге, а в 8 — в макете.

    Но, что с подписью не так? Неужели никто не пользуется такой удобной возможностью? Или я что-то не так делаю?

    Reply
  21. M_W_W

    АУ!!! Автор, Вы там живы? Ответьте пожалуйста…

    Reply
  22. M_W_W

    На Мисте целую тему сделал — http://www.forum.mista.ru/topic.php?id=811721#7, ничего не получается… Но, сюда не переношу, так, как к сабжевой обработке это имеет уже малое отношение, там я уже переписал подписание на vbs, и прочие эксперименты проделывал… Чего-то не то с кодировкой. Это все хорошо, я надеюсь добью все-таки подписание… Но:

    Мне все-таки интересно, у кого-нибудь вообще работает сабжевая разработка, в исходном виде, так сказать — «из коробки» — ???

    Опубликована давно, народ скачивал… И тишина… И автор пропал…

    Reply
  23. M_W_W
    Reply
  24. Dionisiy

    Работает

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *