Примеры работы с API в Честный знак (обувь)

04.09.20

Интеграция - Обмен с ГосИС

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
Пример выгрузки маркировок в ЧЗ
.epf 9,66Kb
49
49 Скачать (1 SM) Купить за 1 850 руб.

Для начала вы должны быть зарегистрированы в Честном знаке(https://shoes.crpt.ru/) и иметь сертификат для входа. Честный знак нам предлагает воспользоватся инструкцией по ссылке https://shoes.crpt.ru/docs/API_Track_and_Trace_Government_Information_System_v18_en.pdf она вам поможет, но обращайте внимание, что там довольно много неточностей и устаревших данных.

Начнем с того что нам нужно получить токен для работы с API честного знака. Для этого нам нужно сделать GET запрос в ответ на который мы получим поля GUID(Уникальный идентификатор) и DATA(Данные).

GET Запрос из 1с выглядит следующим образом: 

    сайт = "ismp.crpt.ru";
	хСоединение =    Новый HTTPСоединение(Сайт,443,,,,,Новый ЗащищенноеСоединениеOpenSSL);
	Запрос = новый HTTPЗапрос("/api/v3/auth/cert/key");
	хОтвет = хСоединение.ВызватьHTTPМетод("GET",Запрос);
	
	Если хОтвет.КодСостояния <> 200 Тогда
		
		Сообщить("Ошибка. Код ответа " + хОтвет.КодСостояния);
		
		Возврат;
	КонецЕсли;
	Сообщение = хОтвет.ПолучитьТелоКакСтроку("UTF-8"); 
	
	//десериализуем данные о клиенте из JSON 
	ЧтениеJSON = Новый ЧтениеJSON; 
	ЧтениеJSON.УстановитьСтроку(Сообщение); 
	ОборудованиеJSON = ПрочитатьJSON(ЧтениеJSON); 
	ЧтениеJSON.Закрыть();
	УИД = ОборудованиеJSON.uuid;
	Данные = ОборудованиеJSON.data;
	Файл = Новый ЗаписьТекста("C:\1\test.txt");
	Файл.ЗаписатьСтроку(Данные);
	Файл.Закрыть();	

Данные нам необходимо подписать нашей электронной подписью и прислать в ответ ЧЗ. Для того что бы подписать данные воспользуемся сайтом КриптоПРО https://www.cryptopro.ru/sites/default/files/products/cades/demopage/cades_bes_sample.html Там нам нужно выбрать наш сертификат, а  в поле "Данные для подписи" вставить полученные данные(в моем случае текст из файла test.txt). 

Сформированную подпись копируем в текстовый файл и с помощью Notepad избавляемся от пробелов и переносов строки. Выделяем весь текст жмем Ctrl+H в поле поиска пишем \n затем \r поле замены оставляем пустым. Жмем заменить все.

GUID и текст из получившегося файла нам нужно отправить POST запросом в ЧЗ.

Процедура ПолучитьТокенНаСервере()
	Текст = Новый ТекстовыйДокумент;
	ПолноеИмяФайла = "C:\1\out.txt";
	Текст.Прочитать(ПолноеИмяФайла);
	КоличествоСтрок = Текст.КоличествоСтрок();
	Данные = "";
	Для Счетчик = 1 по КоличествоСтрок Цикл
		ТекСтрока = Текст.ПолучитьСтроку(Счетчик);
		Данные = Данные + ТекСтрока;
	КонецЦикла;
	Соединение = Новый HTTPСоединение("ismp.crpt.ru",443,,,,,Новый ЗащищенноеСоединениеOpenSSL);
	Заголовки = Новый Соответствие;
	
	Заголовки.Вставить("Content-Type", "application/json; charset=UTF-8");
	Заголовки.Вставить("Accept", "application/json");
	
	Запрос = Новый HTTPЗапрос("/api/v3/auth/cert/",Заголовки);
	ЗаписьJOIN = Новый ЗаписьJSON;
	ЗаписьJOIN.УстановитьСтроку();
	ДанныеДляЗапроса = Новый Структура;
	ДанныеДляЗапроса.Вставить("uuid",УИД);
	ДанныеДляЗапроса.Вставить("data",Данные);	
	ЗаписатьJSON(ЗаписьJOIN,ДанныеДляЗапроса);
	СтрокаДляЗапроса = ЗаписьJOIN.Закрыть();
	
	//Формируем ответ клиенту
	Запрос.УстановитьТелоИзСтроки(СтрокаДляЗапроса,КодировкаТекста.UTF8,
	ИспользованиеByteOrderMark.НеИспользовать);
	
	Ответ = Соединение.ОтправитьДляОбработки(Запрос);
	Если Ответ.КодСостояния <> 200 Тогда
		
		Сообщить("Ошибка. Код ответа " + Ответ.КодСостояния);
		ЧтениеJSON = Новый ЧтениеJSON;
		Сообщение = Ответ.ПолучитьТелоКакСтроку("UTF-8");
		ЧтениеJSON.УстановитьСтроку(Сообщение); 
		СообщениеJSON = ПрочитатьJSON(ЧтениеJSON); 
		ЧтениеJSON.Закрыть();
		Сообщить(СообщениеJSON.error_message);
		
		Возврат;
	КонецЕсли;
	
	ЧтениеJSON = Новый ЧтениеJSON;
	ЧтениеJSON.УстановитьСтроку(Ответ.ПолучитьТелоКакСтроку());
	
	Токен = ПрочитатьJSON(ЧтениеJSON, Ложь).token;				
	
КонецПроцедуры

В ответ мы получим токен который нужно будет использовать в любых дальнейших запросах.

После получения токена можно использовать любые методы работы с документами и маркировками описанными в документации. Вот мой пример получения маркировок находящихся в обороте. 

сайт = "ismp.crpt.ru";
	хСоединение =    Новый HTTPСоединение(Сайт,443,,,,,Новый ЗащищенноеСоединениеOpenSSL);
	Запрос = новый HTTPЗапрос("/api/v3/facade/identifytools/listV2?cisStatus=INTRODUCED&limit=10000");
	запрос.Заголовки.Вставить("Authorization","Bearer "+Токен);
	хОтвет = хСоединение.ВызватьHTTPМетод("GET",Запрос);	
	Если хОтвет.КодСостояния <> 200 Тогда
		
		Сообщить("Ошибка. Код ответа " + хОтвет.КодСостояния);
		ЧтениеJSON = Новый ЧтениеJSON;
		Сообщение = хОтвет.ПолучитьТелоКакСтроку("UTF-8");
		ЧтениеJSON.УстановитьСтроку(Сообщение); 
		СообщениеJSON = ПрочитатьJSON(ЧтениеJSON); 
		ЧтениеJSON.Закрыть();
		Сообщить(СообщениеJSON.error_message);
		Возврат;
	КонецЕсли;
	Сообщение = хОтвет.ПолучитьТелоКакСтроку("UTF-8"); 
	
	//десериализуем данные о клиенте из JSON 
	ЧтениеJSON = Новый ЧтениеJSON; 
	ЧтениеJSON.УстановитьСтроку(Сообщение); 
	ОборудованиеJSON = ПрочитатьJSON(ЧтениеJSON); 
	ЧтениеJSON.Закрыть();
	Результат = ОборудованиеJSON.results;
	Для Каждого Строка Из Результат Цикл
		НоваяСтрока = ТаблицаВыбывших.Добавить();
		НоваяСтрока.Маркировка = Строка.cis;		
	КонецЦикла;

Теперь нам необходимо отгрузить маркировки другому юр.лицу. Изначально я пытался создать документ с помощью API в формате JSON, но постоянные ошибки заставили меня сделать это через XML. Выглядело это следующим образом. Сначала я создаю JSON документ 

	РеквизитыДокумента = Новый Структура;	
	РеквизитыДокумента.Вставить("trade_participant_inn_sender",ИННСобственника);   //ИНН собственника
	РеквизитыДокумента.Вставить("trade_participant_inn_receiver",ИННПолучателя); //ИНН получателя
	РеквизитыДокумента.Вставить("trade_participant_inn_owner",ИННСобственника);   //ИНН собственника
	РеквизитыДокумента.Вставить("transfer_date",Формат(ТекущаяДата(),"ДФ=dd.MM.yyyy")); //Дата передачи маркированных товаров
	РеквизитыДокумента.Вставить("move_document_number",НомерДокумента); //Номер первичного документа	
	РеквизитыДокумента.Вставить("move_document_date",Формат(ДатаДокумента,"ДФ=dd.MM.yyyy")); //Дата первичного документа
	РеквизитыДокумента.Вставить("turnover_type","SELLING");   //Код типа отгрузки		                  	
	Товары = Новый Массив;
	Для Каждого Строка ИЗ ТаблицаМаркировок Цикл
		Отбор = Новый Структура;
		Отбор.Вставить("Маркировка",Строка.Маркировка);	
		Если ТаблицаВыбывших.НайтиСтроки(Отбор).Количество() > 0 Тогда
			СтруктураТоваров = Новый Структура;
			СтруктураТоваров.Вставить("ki","<![CDATA["+Строка.Маркировка+"]]>"); //Уникальный идентификатор товара
			СтруктураТоваров.Вставить("cost",Строка.Цена); 
			СтруктураТоваров.Вставить("vat_value",Строка.НДС); 	
			Товары.Добавить(СтруктураТоваров);
		КонецЕсли;	
	КонецЦикла;
	РеквизитыДокумента.Вставить("product",Товары);   //ИНН собственника
	
	ЗаписьJSON = Новый ЗаписьJSON;
	ЗаписьJSON.ОткрытьФайл("C:\1\pills.json");
	ЗаписатьJSON(ЗаписьJSON,РеквизитыДокумента);
	ЗаписьJSON.Закрыть();	

На структуру полей можно ориентироваться с помощью документации и данного шаблона XML

<?xml version="1.0" encoding="UTF-8"?>
<shipment version="4" action_id="10">
    <trade_participant_inn_sender>6317136467</trade_participant_inn_sender>
    <trade_participant_inn_receiver>7721546864</trade_participant_inn_receiver>
    <trade_participant_inn_owner>6317136467</trade_participant_inn_owner>
    <transfer_date>05.12.2019</transfer_date>
    <move_document_number>123</move_document_number>
    <move_document_date>05.12.2019</move_document_date> <!-- Комментарий -->
    <turnover_type>SELLING</turnover_type>
    <products_list>
        <product>
            <ki><![CDATA[0147012334793726213D6uKeCK7LtuO]]></ki>
            <cost>33030.5</cost>
            <vat_value>270.85</vat_value>
        </product>
    </products_list>
</shipment>

Полученный JSON файл мы загружаем в конвентер JSON-XML. Я использовал этот https://www.convertjson.com/json-to-xml.htm Он немного криво конвентирует поэтому после конвертации приводим вид файла по шаблону. 

Полученный xml файл нам остается загрузить в честный знак. Для этого заходим в список документов в ЧЗ. Внизу нажимаем кнопку загрузить, выбираем пункт отгрузка и загружаем наш XML файл. После успешной загрузки без единой ошибки другое юр. лицо может принят себе отгруженные маркировки с помощью создания документа приемки.

Обработка тестировалась на платформе: 8.3.11.3034.

Честный знак API ЧЗ 1C

См. также

Бюджетный учет Обмен с ГосИС Бухгалтер Пользователь Бухгалтерский учет 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 1С:Управление холдингом Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Управляйте учетной политикой раздельного учета ГОЗ в 1С:Бухгалтерия 3.0 ПРОФ/КОРП и УХ 3.2. Отчеты по исполнению госконтрактов, расчетно-калькуляционные материалы и контроль операций для исполнения в срок. Готовое расширение подходит для всех бухгалтеров и руководителей производства, помогая вести правильный учет по гособоронзаказу в соответствии 275-ФЗ. Профессиональный консалтинг и регулярные обновления продукта.

28.08.2020    300088    2099    vvmanannikov    133    

985

Бюджетный учет Обмен с ГосИС Бухгалтер Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Государственные, бюджетные структуры Россия Бухгалтерский учет Платные (руб)

Доработка конфигурации 1С:Бухгалтерия предприятия, редакция 3.0. реализована в виде расширения. Предназначена для ведения раздельного учета и автоматизации заполнения отчетности исполнения контрактов ГОЗ в конфигурациях 1С БП КОРП, ПРОФ, БИТ.ФИНАНС.

55200 руб.

16.08.2019    91929    234    87    

140

SALE! 40%

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

Интеграция и синхронизация Честный Знак и 1C - полноценная обработка, которая манипулирует сотнями задач по ведению учета в системе мониторинга честный знак, особенности: такие как полная поддержка учета карточек в национальном каталоге (модерация, редактирование, подписание, получение информации), получение кодов маркировок в станции управления заказами "СУЗ Облако", удобная отправка и получение "УПД" через систему "ЭДОЛайт" из документов реализации или корректировки, так же существует механизм приема через ЭДОЛайт, отправка и получения таких документов как перемаркировка , списание, отгрузка и еще более 40 типов документов в ГИСМТ которые описаны ниже, моментальное сопоставление и внедрение в типовую конфигурацию которое обеспечивает ракетную мега скорость

18000 10800 руб.

28.03.2023    17621    110    21    

90

Бюджетный учет Обмен с ГосИС Бухгалтер Пользователь Бухгалтерский учет 1С:Управление производственным предприятием Государственные, бюджетные структуры Россия Бухгалтерский учет Платные (руб)

Для 1С: УПП 1.3 предлагаем Вашему вниманию подсистему "Раздельный учет результатов финансово-хозяйственной деятельности организаций, выполняющих государственный оборонный заказ (раздельный учет ГОЗ)". Ключевые возможности подсистемы: - Автоматическое заполнение регламентированного отчета «Исполнение контрактов ГОЗ»; - Расшифровка показателей отчета об исполнении контрактов ГОЗ с детализацией до документов; - Контроль хозяйственных операций на соответствие требованиям Постановления Правительства № 47; - Автоматизированный ввод начальных данных по контрактам, заключенным ранее даты начала использования подсистемы.

90000 руб.

25.09.2020    30667    42    10    

40

SALE! 20%

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

Полнофункциональное расширение (ранее известное как Модуль 1С-ЕГАИС) для взаимодействия типовых конфигураций 1С и ЕГАИС, предоставляющее максимум возможностей по работе с УТМ. Получение и отправка ТТН, отправка акта о постановке на баланс и акта о списании. Получение остатков. Загрузка и сопоставление номенклатуры и контрагентов. Оправка в ЕГАИС отчетов о производстве и импорте.

8970 7176 руб.

15.12.2015    170792    955    364    

400

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

Расширение конфигурации для УТ 11.5, КА 2.5 ,ERP 2.5 (Управляемые формы) позволяет выполнять печать кассовых чеков на одну ККМ 54-ФЗ с нескольких рабочих мест. НИКАКИХ НАСТРОЕК В РАЗРАБОТКЕ - ПОДКЛЮЧИЛ И ПЕЧАТАЙ. Если у вас несколько отделов и одна ККМ - печатайте на одной ККМ! Если у вас две ККМ и одна поломалась - печатайте на одной ККМ, пока ремонтируете другую!

4500 руб.

27.08.2018    122185    1025    584    

864

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

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

60000 руб.

19.12.2022    12011    34    20    

21

Оптовая торговля Производство готовой продукции (работ, услуг) Розничная торговля Обмен с ГосИС Программист Бухгалтер Пользователь Платформа 1С v8.3 Конфигурации 1cv8 Сельское хозяйство и рыболовство Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Рестораны, кафе и фаст-фуд Пищевая промышленность Россия Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная конфигурация Хамелеон Меркурий для взаимодействия с системой Меркурий (тестовый+рабочий+демо контур) может использоваться для интеграции в любую конфигурацию на базе 1С, версии ПРОФ и выше. Основное отличие от других решений - работа через веб-интерфейс и API 2.0(API 2.1). Для удобства реализован общий интерфейс в виде обработки, схожей с интерфейсом Меркурий, но возможностей гораздо больше, т.к. при интеграции в Вашу учетную систему, можно на основании Ваших справочников и документов, создавать соответствующие документы и справочники в системе Меркурий и наоборот.

44000 руб.

08.11.2017    122941    292    140    

398
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SeTIrk 29.06.20 09:09 Сейчас в теме
Извините, а разве отгрузка и приемка не через ЭДО идет?
Я считал что в ЭДО подписанный документ с двух сторон отправляется в Честный Знак силами ЭДО. Важно в ЭСФ передать в полях ДопСведТов.НомСредИдентТов.НомУпак или КИЗ
3. stas8359 25 30.06.20 15:11 Сейчас в теме
(1)Все правильно. Но есть ситуации, когда нужно получить или выгрузить данные через Api ЧЗ.
11. EdBush 20.07.20 10:10 Сейчас в теме
Функция ПодписатьЭЦПЧерезСОМОбъекты(СтрокаДляПодписи, СтрокаВBase64 = Истина, Открепл) Экспорт
    
    Попытка
        comStore = Новый COMОбъект("CAdESCOM.Store");
        comCPSigner = Новый COMОбъект("CAdESCOM.CPSigner"); // Аналог "CAPICOM.Signer".
        comSignedData = Новый COMОбъект("CAdESCOM.CadesSignedData");
    Исключение
        Сообщить("Не установлен КриптоПро!");
        Возврат "";
    КонецПопытки;
    
    comStore.Open(
        2, // StoreLocation - CAPICOM_CURRENT_USER_STORE.
        "MY", // StoreName
        ); // OpenMode - CAPICOM_STORE_OPEN_READ_ONLY.
    comCertificates = comStore.Certificates;
    comStore.Close();
    comStore = Неопределено;
    КоличествоСертификатов = comCertificates.Count;
    
    Если КоличествоСертификатов > 0 Тогда
        // Убрать "сертификаты, в которых отсутствует закрытый ключ".
        comCertificates = comCertificates.Find(6, 2); // (CAPICOM_CERTIFICATE_FIND_EXTENDED_PROPERTY, CAPICOM_PROPID_KEY_PROV_INFO)
        КоличествоСертификатов = comCertificates.Count;
    КонецЕсли;
    Если КоличествоСертификатов > 0 Тогда
        // Оставить "только сертификаты, действительные в настоящее время".
        comCertificates = comCertificates.Find(9, ); // (CAPICOM_CERTIFICATE_FIND_TIME_VALID, "the current time is assumed")
        КоличествоСертификатов = comCertificates.Count;
    КонецЕсли;
    
    Если КоличествоСертификатов = 1 Тогда
        comСертификат = comCertificates.Item(1); // Выбрать единственный.
        
    ИначеЕсли КоличествоСертификатов = 0 Тогда
        comCertificates = Неопределено;
        comCPSigner = Неопределено;
        comSignedData = Неопределено;
        Сообщить("Не найдены актуальные ключи ЭЦП для подписи данных!");
        Возврат "";
        
    Иначе
        СертификатыДляВыбора = Новый СписокЗначений;
		флНашли = Ложь;
		Для i = 1 По КоличествоСертификатов Цикл 
			СертификатыДляВыбора.Добавить(i, comCertificates.Item(i).SubjectName);
			comСертификат = comCertificates.Item(i);
			Если (Найти(comСертификат.SubjectName,"ИНН="+Док.Фирма.ИНН)>0) ИЛИ
				(Найти(comСертификат.SubjectName,"ИНН=00"+Док.Фирма.ИНН)>0) Тогда
				флНашли = Истина;
				Прервать;
			КонецЕсли;
            
        КонецЦикла;
		Если НЕ флНашли Тогда
			i = СертификатыДляВыбора.ВыбратьЭлемент();
			Если i = Неопределено Тогда
				comCertificates = Неопределено;
				comCPSigner = Неопределено;
				comSignedData = Неопределено;
				Сообщить("Не выбран ключ ЭЦП!");
				Возврат "";
				
			Иначе
				comСертификат = comCertificates.Item(i.Значение); // Выбрать указанный пользователем.
				
			КонецЕсли;
		КонецЕсли;
        
    КонецЕсли;
    comCertificates = Неопределено;
    
    comCPSigner.Certificate = comСертификат;
    // + Что-то из этого может быть нужным.
//    comCPSigner.TSAAddress = "http://cryptopro.ru/tsp/";
//    comCPSigner.Options = 0; // CAPICOM_CERTIFICATE_INCLUDE_CHAIN_EXCEPT_ROOT. Ещё есть CAPICOM_CERTIFICATE_INCLUDE_WHOLE_CHAIN и CAPICOM_CERTIFICATE_INCLUDE_END_ENTITY_ONLY.
    // -
    comСертификат = Неопределено;
    
    Если СтрокаВBase64 Тогда // Очень важно!
        comSignedData.ContentEncoding = 1; // CADESCOM_BASE64_TO_BINARY
    //Иначе // Так и остаётся 0 - CADESCOM_ENCODE_BINARY
    КонецЕсли;
    comSignedData.Content = СтрокаДляПодписи;
    ПодписанныеДанные = comSignedData.SignCades(
        comCPSigner, // Signer
        1, // CadesType, CADESCOM_CADES_BES.
        Открепл, // bDetached - "флаг открепленной подписи (исходное сообщение не включается в итоговый CMS-контейнер)".
        ); // EncodingType - по умолчанию CAPICOM_ENCODE_BASE64.
    
    comCPSigner = Неопределено;
    comSignedData = Неопределено;
    Возврат УбратьСимволы1013(ПодписанныеДанные);
    
КонецФункции
Показать
user1049861; clev; +2 Ответить
2. serko8547 111 29.06.20 14:32 Сейчас в теме
а есть пример запроса API по сигаретам?
maksa2005; +1 Ответить
4. stas8359 25 30.06.20 15:12 Сейчас в теме
(2)Нет, работал только с обувью.
5. user1430516 01.07.20 19:05 Сейчас в теме
Каждый раз нужно возится с сертификатом, или можно как то автоматически подписать данные? Токен, как я понял, живет только 10 часов.
maksa2005; +1 Ответить
6. yursa26 11.07.20 11:39 Сейчас в теме
А есть вариант отправки документа отгрузки запросом ч/з АПИ, а не руками на сайте?
8. maksa2005 550 15.07.20 10:43 Сейчас в теме
7. maksa2005 550 15.07.20 10:32 Сейчас в теме
Спасибо за развернутую документацию
10. EdBush 20.07.20 10:09 Сейчас в теме
ТелоЗапроса = Новый Структура;
	ТелоЗапроса.Вставить("document_num",   СокрЛП(Док.Номер));
	ТелоЗапроса.Вставить("document_date",    ДатаUTC(Док.Дата));//"2019-11-14T00:00:00.000Z");
	ТелоЗапроса.Вставить("transfer_date", ДатаUTC(ТекущаяДата()));//(Док.Дата));
	ТелоЗапроса.Вставить("receiver_inn", СокрЛП(Док.Контрагент.ИНН));
	ТелоЗапроса.Вставить("sender_inn", СокрЛП(Док.Фирма.ИНН));
	ТелоЗапроса.Вставить("turnover_type", "SELLING");
	ТелоЗапроса.Вставить("to_not_participant", "false");
	
	ТелоЗапроса.Вставить("products", Новый Массив);
	
	Запрос = Новый Запрос("ВЫБРАТЬ
	                      |	ОтгрузкаСоСкладаТоварыШК.ШК,
	                      |	ОтгрузкаСоСкладаТоварыШК.Номенклатура
	                      |ИЗ
	                      |	Документ.ОтгрузкаСоСклада.ТоварыШК КАК ОтгрузкаСоСкладаТоварыШК
	                      |ГДЕ
	                      |	ОтгрузкаСоСкладаТоварыШК.Ссылка.Основание = &Основание");
	Запрос.Параметры.Вставить("Основание", Док);
	Выб = Запрос.Выполнить().Выбрать();
	Пока Выб.Следующий() Цикл
		СтрокаТЧ = Новый Структура;
		СтрокаТЧ.Вставить("uit_code", СокрЛП(Выб.ШК));
		СтрокаТЧ.Вставить("product_description", СокрЛП(Выб.Номенклатура.Наименование));
		ТелоЗапроса.products.Добавить(СтрокаТЧ);
	КонецЦикла;
	ЗаписьJSON = Новый ЗаписьJSON();
	ПараметрыЗаписиJSON = Новый ПараметрыЗаписиJSON(ПереносСтрокJSON.Нет, "");
	ЗаписьJSON.УстановитьСтроку(ПараметрыЗаписиJSON);
	
	ЗаписатьJSON(ЗаписьJSON, ТелоЗапроса);
	
	ТекстJSON = ЗаписьJSON.Закрыть();
	
	
	ТекстXML64 = ШтрихкодВBase64(ТекстJSON);
	ПодписанныеДанные = ПодписатьЭЦПЧерезСОМОбъекты(ТекстXML64, Истина, Истина);
	HTTP = Новый HTTPСоединение("ismp.crpt.ru", 443, , , , , Новый ЗащищенноеСоединениеOpenSSL);
	//URLЗапроса = "/api/v3/lk/documents/shipment/create";
	URLЗапроса = "/api/v3/lk/documents/create";
	HTTPЗапрос = Новый HTTPЗапрос(URLЗапроса);
	HTTPЗапрос.Заголовки.Вставить("Content-Type",   "application/json");
	HTTPЗапрос.Заголовки.Вставить("Authorization", "Bearer "+СокрЛП(Док.Фирма.ТокенЧЗ));
	
	ТелоЗапроса = Новый Структура;
	ТелоЗапроса.Вставить("product_document", ТекстXML64);
	ТелоЗапроса.Вставить("document_format",  "MANUAL");
	ТелоЗапроса.Вставить("product_group",  "shoes");
	ТелоЗапроса.Вставить("type",  "LP_SHIP_GOODS");
	ТелоЗапроса.Вставить("signature",        ПодписанныеДанные);
	ЗаписьJSON = Новый ЗаписьJSON();
	ПараметрыЗаписиJSON = Новый ПараметрыЗаписиJSON(ПереносСтрокJSON.Нет, "");
	ЗаписьJSON.УстановитьСтроку(ПараметрыЗаписиJSON);
	ЗаписатьJSON(ЗаписьJSON, ТелоЗапроса);
	
	ТекстJSON = ЗаписьJSON.Закрыть();
	HTTPЗапрос.УстановитьТелоИзСтроки(ТекстJSON, КодировкаТекста.UTF8, ИспользованиеByteOrderMark.НеИспользовать);
	Ответ = HTTP.ОтправитьДляОбработки(HTTPЗапрос);
	ИДДок = Ответ.ПолучитьТелоКакСтроку();
	Сообщить(ИДДок);
	ДокОб = Док.ПолучитьОбъект();
	ДокОб.ИдентификаторЧЗ=ИДДок;
	ДокОб.СтатусЧЗ="";
	ДокОб.ОшибкаЧЗ="";
	ДокОб.ДействиеЧЗ="";
	Попытка
		ДокОб.Записать(РежимЗаписиДокумента.Запись);
	Исключение
	КонецПопытки;
Показать
MKozzlik; clev; +2 Ответить
18. MKozzlik 25.09.20 11:46 Сейчас в теме
(10) А если ИДДок получен и код ответа -201, то есть успешно создан документ, где его можно найти в честном знаке? в документах ничего нет, пока тренируюсь на тестовом сервере, то есть demo.lp.crpt.tech
20. Mx00 249 15.10.20 17:16 Сейчас в теме
12. _Enot_ 9 23.07.20 20:40 Сейчас в теме
а в поле "Данные для подписи" вставить полученные данные
А какие данные нам именно нужно скопировать? Возвращает ошибку 500. Подпись не валидна
13. _Enot_ 9 24.07.20 07:41 Сейчас в теме
Разобрался. То что вы получили в файл test. txt нужно скопировать и подписать на сайте крипто про, потом \n и \r заменить все и скопировать получившиеся в out. txt. После этого получаем токен. Автор пожалуйста, в статье укажите конкретнее про это пункт. А так все норм, спасибо, лайк)))
d4rkmesa; +1 Ответить
15. user1075117 02.09.20 21:46 Сейчас в теме
(13) А не можете подсказать, что именно вы добавляете на сайте крипто-про, так как пробовал и из первого кода ОборудованиеJSON.uuid ОборудованиеJSON.data; Возвращает всегда подпись не валидна
16. _Enot_ 9 03.09.20 07:28 Сейчас в теме
(15)То,что получаю в файл test.txt .
14. elephant_x 145 27.08.20 17:28 Сейчас в теме
Было у кого-то такое?
В честный знак захожу без проблем, а при получении токена вот такая ошибка:

Ошибка. Код ответа 400
Организация не зарегистрирована
17. elephant_x 145 10.09.20 13:23 Сейчас в теме
(14) Обращайте внимание тестовый сервер или продуктивный, у меня была в этом проблема)
19. Mx00 249 15.10.20 17:12 Сейчас в теме
в типовых 1С 8 всё есть (и в июне 2020 тоже было), зачем такие сложности?
21. carapuzzz 07.11.20 12:44 Сейчас в теме
(19)
согласен взять любую конфу от 1с за день разобраться не составит труда.
но есть сам апи честного знака это УГ часть функций не работают как нужно, за два месяца работы с ними они уже сменили 2 версии причем функции постоянно устаревают. нужна была функция для получения информации по марке.
непонятно зачем делать несколько функций для одного и того же но, одна функция возвращает данные по марке, другая нет, причем по другой марке все с точностью до наоборот, техподдержка ни разу не ответила.
Выкладываю их описание, написано коряво но разобраться можно.
Прикрепленные файлы:
Описание_API_ГИС_МТ.pdf
22. Mx00 249 07.11.20 15:04 Сейчас в теме
(21) у меня есть описание API :-)
я всё сделал для 1С 7.7 и это несколько сложнее чем для 1С 8.3 т.к. не было примеров
но даже то, что ты тут "наваял" вообще полная хрень - зачем использовать конвентер JSON-XML ?
проще сразу XML формировать !
а уж подпись обрабатывать через блокнот вообще хрень полная...
подумай тем ли ты занимаешься? может пора сменить профессию?!?
23. carapuzzz 07.11.20 16:27 Сейчас в теме
(22)ничего не ваял статья не моя, см кто автор, пост не только для тебя а всем кто хочет докопаться до истины, выложил свежее описание. согласился лишь с тем, что все есть в типовых конфигурациях.
24. Mx00 249 08.11.20 19:06 Сейчас в теме
(23) тогда я не понял зачем мне ответил... да и прикреплять описание смысла нет, т.к. оно есть на сайте ЧЗ
извини за наезд ;-)
27. user112345 17.03.21 12:21 Сейчас в теме
(24) Хм, а можно вопросик любителю типовой, в которой "всё есть"? Допустим, база на облачном арендуемом сервере, доступ в инет закрыт вообще (и не откроют, и даже если попросить, и даже если очень-очень попросить), доступ к установке криптопровайдера на сервере закрыт, доступ к установке сертификатов на сервере закрыт.
Как там с типовой 1С, где всё есть, всё ещё никаких сложностей?
28. Mx00 249 17.03.21 12:59 Сейчас в теме
(27) Хм, не понял сути вопроса. В публикации автор (не я) написал про подключение к ЦРПТ из 1С, а вы меня троллите гипотетической ситуацией "инет закрыт вообще" - у вас весеннее обострение? :-)
29. SnorkL1 3 17.03.21 14:19 Сейчас в теме
(28) Я не тролю, просто практически в каждой онторе, где мне случалось пересекаться с типовым механизмом ЭДО в конфах 1С, "всё есть" никогда нормально не работало, поэтому коммент типа вашего самого первого под этой статьёй, вызывают у меня слегка негативные эмоции. Их я вам и изложил (частично), можете расценивать это как крик души :)
30. Mx00 249 17.03.21 14:52 Сейчас в теме
(29) а ты кто такой? от куда тут взялся ещё один тролль ? ;-)
31. SnorkL1 3 17.03.21 18:44 Сейчас в теме
(30) по "всё есть в типовой" сказать было нечего, поэтому сразу перешёл на личности? ;)
32. Mx00 249 17.03.21 19:55 Сейчас в теме
(31) ну честно ответь какое отношение ты имеешь к user112345 ?
а что касается "всё есть в типовой" - то действительно есть, маркировка там есть, а если ты не отличаешь ЭДО от маркировки, то это твои личные трудности. Если ты напишешь чего нет в типовой по маркировке в контексте темы автора, то я ещё смогу что-то ответить, а так считаю тебя троллем с весенним обострением :-)
33. SnorkL1 3 18.03.21 11:58 Сейчас в теме
(32) что за странный вопрос, какое я отношение имею к своему нику, который выбрал совершенно произвольно. Раз система мне дала под ним зарегиться - значит наверное имею, это мой ник теперь на инфостарте, разве нет? А, вижу, кто-то его уже в моем профиле поменял на адрес почты, забавное отношение у администраторов сайта к хранению персональных данным пользователей.

В контексте темы автора, лично к автору я вообще ни одной претензии не предъявил, он как раз молодец, очень подробно написал. Я ответил на твой первый коммент. Может, ЧСВ у тебя плохо влияет на память, так я напомню. Ты спросил у автора, зачем он вообще заморачивался с АПИ Честного знака, если "в типовой всё есть". Любые инструкции по интеграции типовых с Честным знаком первым пунктом включают настройку ЭДО. Это по поводу того. что я "не отличаю ЭДО от маркировки". Я пока только разбираюсь с реализацией функционала маркировок Честный знак (в УТ11.4), поэтому и ищу по форумам ответы на появляющиеся вопросы. Вот, на Мисте нашёл что в принципе маркировки можно не через ЭДО загружать, а вносить вручную. Пока тестирую...
34. Mx00 249 18.03.21 13:33 Сейчас в теме
(33) я вижу, что сообщение 27 написано пользователем user112345, а сообщение 29 написано SnorkL1 и это разные пользователи
Прикрепленные файлы:
36. SnorkL1 3 18.03.21 14:06 Сейчас в теме
(34) писал с одного компа, ничего не менял. С утра вместо user у меня в никнейме отображался адрес электронной почты, поэтому я в профиле его поменял на SnorkL1
35. Mx00 249 18.03.21 13:51 Сейчас в теме
(33) теперь про маркировку:
хорошо, что ты написал про "Я пока только разбираюсь с реализацией функционала маркировок", теперь хоть мне понятен твой уровень претензии :-)
ты не понял вообще сути того, что я написал автору. Автор изобретал собственный велосипед вместо того чтобы разобраться с нормальной реализацией API в типовых и при этом он дал ссылку на документацию на английском языке... видимо он был на той же стадии что и ты сейчас и таких как ты запутает вместо того чтобы помогать ;-)
И тебе советую найти правильные места где брать информацию, а то будешь на мисте узнавать то, что есть на сайте честного знака.
Болтать с тобой я больше не буду, просто очень разный уровень понимания маркировки: то, что для тебя "вау открытие", для меня "блин, так делать нельзя - это не правильно"
37. SnorkL1 3 18.03.21 14:08 Сейчас в теме
(35) ай молодец, почесал своё ЧСВ лишний раз. Пробежался по твоим комментам и публикациям - ну, твой уровень мне тоже понятен, согласен, что дальнейший разговор бессмысленен.
40. yudinvs 2 30.06.21 09:42 Сейчас в теме
(35) Аж противно читать. До чего скатились "программисты". Зачем что то читать, зачем разбираться с документацией - возьми да стащи с типовой и все.... Кстати в 2019 году, когда началась маркировка в типовой вообще ничего не было, а маркировка уже была обязательной для производителя и первого получателя от производителя сигарет. Да и на момент публикации статьи, если я не ошибаюсь в типовой тоже было немного, более менее стабильный релиз вышел уже в июне 20.
Героически написали что то для семерки. Это много проще чем для 8, промеров работы с json и веб запросами для 7.7 в интернете много было задолго до, искать надо правильно. Автор молодец хотя бы в том что разобрался и смог получить результат. Сейчас наверняка уже допилил и взаимодействует с API без необходимости монстров в виде типовых модулей.
41. Mx00 249 30.06.21 10:50 Сейчас в теме
(40) Полностью с тобой согласен - нужно читать документацию, но на родном языке, а не на том на котором ничего не понимаешь :-)
пост автора был написан 15 мая 2020, а не 2019-м году и уже было где посмотреть...
Пост автора про обувь, а не про сигареты, поэтому не знаю зачем ты тут про них написал
Если думаешь, что в 7.7 работать с json и подписью проще, чем в 8.3, то это далеко не так, но ты всё равно останешься при своём мнении :-)
даже здесь на инфостарте если написать поиск "api/v3/auth/cert/", то найдём публикацию
https://infostart.ru/public/1214183/ от 22.03.2020, соответственно в типовых уже был механизм взаимодействия с API с Честный знак о чём я и написал

и ещё раз - мне не понравился ОЧЕНЬ КРИВОЙ подход автора и поэтому я написал, что нет смысла изобретать свой велосипед...
42. yudinvs 2 30.06.21 14:28 Сейчас в теме
(41)Мы с вами на брудершафт не пили, так что не надо мне тыкать.
Я делал и для 7.7 и для 8. В 7.7 получилось быстрее, меньше заморочек. Помню что в 8 были заморочки с битовостью платформы, а так же некоторые релизы не работали нормально с json, В 7 было проще она одна, одной версии.
Про 19 год я говорю не в том смысле когда автор сделал, а в том смысле что 1С с типовыми решениями не успевает вовремя и работать по принципу выйдет в типовой - оттуда вырежу - это подход не верный.
Если вы не помните, то маркировка обуви началась сильно раньше марта 2020 года. с 01.03.20 она должна уже была быть обязательной, но утром 1 марта перенесли,а нужно было быть уже готовыми. Стабильный релиз появился только к июню. При чем тут сигареты? Вы не знали что там один оператор и по сути один API, только местами методы отличаются.
У автора вполне себе нормальный подход, просто он не знал как подписать data. Потом ему подсказали и он исправил. И кому то наверное помог.
43. Mx00 249 30.06.21 15:00 Сейчас в теме
(42) Куда катится мир?!?
почему-то меня в который раз пытаются убедить, что работая в 1С нужно убирать переносы строк в блокноте, а xml получать из json
вы точно про 1С тут со мной общаетесь или это ветка для студентов "как сдать лабораторную работу по информатике" ???
такое можно делать когда сам разбираешься, но выкладывать как публикацию, чтобы все думали "вау как круто!" - это уже слишком :-)
46. yudinvs 2 01.07.21 08:44 Сейчас в теме
(43) А где написано что чел выложил чтобы все думали что круто? По моему это только вы так подумали. Человек не выкладывал готовое решение, просто выложил то что смог сам разобраться, ему тут же подсказали как подписать DATA. Успокойтесь, вашу крутость никто не переплюнет, правда не потому что вы самый крутой, а потому что никому это не нужно.
48. Mx00 249 01.07.21 11:38 Сейчас в теме
(46) "выложил то что смог сам разобраться" - я про это и написал: зачем читать документацию на английском языке и разбираться с тем, что уже есть в типовых?
при этом разбираться "с помощью Notepad"...
44. Mx00 249 30.06.21 15:12 Сейчас в теме
(42) а теперь по делу: у меня в 7.7 есть накладные на ~7000 КИ и при попытке разобрать json в котором ещё есть xml от поставщика все парсеры которые я пробовал зависали, в итоге перед парсингом я вырезаю content в формате xml и только потом разбираю json.
Вопрос: как Вы разбираете json в 7.7 и пробовали ли разбирать большие документы?
45. yudinvs 2 01.07.21 08:42 Сейчас в теме
(44)7000 КИ - это всего 14 коробов. В фуре 700 коробов. Это 350 тысяч КИ. Не смешите. Документы большие.... Разбираем как то...
47. Mx00 249 01.07.21 10:47 Сейчас в теме
(45) Какой парсер используется используете?, хотя я так понимаю, что у ваc в накладной будет всего 700 записей КИТУ, а значит с большими документами вы не работаете и любой парсер сможет разобрать такой json
49. yudinvs 2 01.07.21 15:06 Сейчас в теме
(47) Вот жеж выводы.... Парсер json newtonsoft. Вам, конечно, виднее работали мы с большими документами или не работали, но я 7 тысяч марок большим количество не считаю. Самый большой документ на память это примерно 650 тысяч КИЗов + 65 тысяч групповых + 1300 транспортных.
Средняя поставка это 350 тысяч кизов. И да, все надо парсить и проверять.
Если парсер сходу не может проглотить весь набор данных, никто же не мешает кормить его порциями, зачем вы из мелкой проблемы раздуваете такие трудности. Тем более что структура то статическая. Вы реально считаете чем то серьезным разделить json и xml и обработать отдельно? По мне так рядовая задача...
Если мы говорим о накладных, то какой смысл туда пихать 7 тысяч кизов, если в обуви агрегация доступна не только для производителей а для любого УОТ? Я делал агрегацию коробок обуви в паллеты и накладные получались маленькие и удобные. Можно вообще агрегировать всю поставку в один код.

Что касается накладных, то передача кодов между УОТ в табаке только посредством ЭДО, накладные действительно небольшие, это уже ограничения операторов ЭДО.

В общем тема закрыта, дальнейшее обсуждение совершенно не касается публикации. Каждый при своем. Я считаю что автор статьи дал старт многим. Если бы я прочел такую статью в 2019 году, наверняка бы мне помогло. И это было бы быстрее чем, разобраться с тем как это сделали в типовой.
50. Mx00 249 01.07.21 16:09 Сейчас в теме
(49) "Вы реально считаете чем то серьезным разделить json и xml и обработать отдельно" - я это сделал, но продолжаю искать более красивый вариант :-)
"то какой смысл туда пихать 7 тысяч кизов" - не я их пихаю, я их разбираю :-)
"Если бы я прочел такую статью в 2019 году" - согласен, только вот статья от мая 2020-го и только по этому поводу мой комментарий ;-)
51. Mx00 249 01.07.21 16:31 Сейчас в теме
(49) и ещё один вопрос по делу :-)
для работы по API нужна цифровая подпись, но ставить её всем менеджерам "не хорошо", у меня 1С на терминальном сервере и сейчас сделано подписание запуском командного файла с утилитой RunAsUser.exe, т.е. сертификат подписи установлен в реестр windows для специального пользователя, а у обычных пользователей доступа к сертификату нет.
Ищу вариант вообще убрать сертификат подписи с сервера и обрабатывать запросы на рабочей станции в которую воткнут ключ.
Если есть такой опыт, то прошу рекомендаций :-)
52. yudinvs 2 02.07.21 10:14 Сейчас в теме
(51) А вот тут все просто. Я написал веб сервис, который транслирует запросы. (я его тут выкладывал, но качать не советую отсюда, если надо так отдам, так как тут он старый, а так как никому он не интересен не обновлял) На рабочей станции с ключом живет этот веб сервис, слушает запросы, отсылает в црпт, возвращает результат. Это решает не только проблему ключа но работу с https в wiinxp/2003, так как доступ к веб сервису идет по http, а сам он уже обращается к ЦРПТ по https. Если проблем с https в терминале нет, то можно в веб сервисе только токен брать, а работу с апи уже в теримнале. Это будет быстрее. Ну или совсем просто - запустить одну инстанцию 1С по сети на машинке с ключом, получать токен раз в несколько часов, хранить его в константе. Клиенты в терминале ничего не подписывают, берут токен из константы и работают с апи по токену. Токен не привязан к машине откуда он был получен.
53. Mx00 249 02.07.21 11:48 Сейчас в теме
(52) "веб сервис" - хочу ;-)
токен у меня и так хранится в справочнике, точнее два токена для СУЗ и ГИС МТ
но менеджеры отправляют и принимают документы, поэтому нужна подпись произвольных данных, думаю, что именно это и делает веб сервис
54. yudinvs 2 02.07.21 18:15 Сейчас в теме
(53)Я не делал подпись произвольных данных, но не думаю что это проблема.
Вот эти куски помогут - сам веб и работа с сертами.


listener = new HttpListener();
 t = new Thread(Listen);
t.Start();

 public void Listen()
         {
             //return;
             string url = "http://*";
             string port = ""+portnum;
             string prefix = String.Format("{0}:{1}/", url, port);
             try
             {
                 listener.Stop();
             }
             catch
             { };
             
             listener.Prefixes.Add(prefix);
             try
             {
                 listener.Start();
             }
             catch (Exception E)
             {
                 SetText("!!!"+E.Message);
                 SetText(@"Запустите программу от имени администратора вот такую команду:netsh http add urlacl url=""http://*:9999/"" user=%username%",true);
                 return;
             }

             while (true)
             {
                 if (closing) return;

                 
                 //Ожидание входящего запроса
                 HttpListenerContext context;
                 try
                 {
                     context = listener.GetContext();
                     
                 }
                 catch
                 { break; }


                 
                 var thread = new Thread(SendReply);
                 thread.Start(context);

             }
         }


  public void SendReply(object parameter)
         {
             try
             {

                 var context = (HttpListenerContext)parameter;


                 //Объект запроса
                 HttpListenerRequest request = context.Request;

                 //Объект ответа
                 HttpListenerResponse response = context.Response;

                 //Создаем ответ
                 string requestBody;
                 Stream inputStream = request.InputStream;
                 Encoding encoding = request.ContentEncoding;
                 StreamReader reader = new StreamReader(inputStream, encoding);
                 requestBody = reader.ReadToEnd();






                 //this.textBox1.Text += "" + request.HttpMethod + " request was caught: " + request.Url;


                 string qry;

                 try
                 {
                     qry = "" + Uri.UnescapeDataString(request.Url.OriginalString);
                 }
                 catch
                 {
                     return;
                 }
                 if (qry.Contains("favicon.ico"))
                 {
                     return;
                 }



                 //SetText(" request was caught: " + qry);

                 qry = qry.Replace("http://", "");

                 try
                 {

                     string res;
                     res = "Error";

                     string rr = qry.Split('/')[0];

                     bool error = false;
                     if (qry.Contains("кусочек урла - команда")) 
                     {
Вот тут берем содержимео запроса (requestBody ), подписываем и отправляем в чз, читаем ответ, присваем его res, отдаем клиенту.

                       }



 response.StatusCode = (int)HttpStatusCode.OK;
 byte[] buffer = Encoding.UTF8.GetBytes(res);

                         response.ContentLength64 = buffer.Length;
                         Stream output = response.OutputStream;
                         output.Write(buffer, 0, buffer.Length);

}





//Работа с сертификатами


public byte[] SignMe(byte[] msg, X509Certificate2 signerCert, bool detached = true)
        {
            ContentInfo contentInfo = new ContentInfo(msg);
            SignedCms signedCms = new SignedCms(contentInfo, detached);            
            CmsSigner cmsSigner = new CmsSigner(signerCert);
            cmsSigner.IncludeOption = X509IncludeOption.EndCertOnly;            
            signedCms.ComputeSignature(cmsSigner);                                    
            
            
            return signedCms.Encode();
        }

//Список сертификатов
 private void GetCerList(string certid)
        {


            X509Store store = new X509Store(StoreLocation.CurrentUser);
            store.Open(OpenFlags.ReadOnly);
            X509CertificateCollection certCollection = store.Certificates;
            

            foreach (X509Certificate2 c in certCollection)
            {
                
                this.comboBox1.Items.Add(c.Subject);
                if (c.GetSerialNumberString() == certid)
                {
                    this.comboBox1.SelectedIndex = this.comboBox1.Items.Count - 1;
                }
                
            }

            store.Close();


        }

Показать
55. ЗС1 15.11.21 23:34 Сейчас в теме
(22) Будьте добры, можете дать для 7.7 работающий код получения токена ЧЗ и выгрузки отгрузки или принятия КИ. Есть такая задачка, но в 7.7 давно не писал. Был бы очень благодарен!
56. Mx00 249 16.11.21 00:09 Сейчас в теме
(55) Получение токена
	// Получаем случайные данные для формирования запроса на новый токен
	// 1.2.1. Запрос авторизации при единой аутентификации
	WinHttp = Создатьобъект("WinHttp.WinHttpRequest.5.1");
	//ТекстЗапроса=Маркировка_АдресИСМП+"/auth/cert/key";
	ТекстЗапроса=Маркировка_АдресTrueAPI+"/auth/key";
	WinHttp.Open("GET",ТекстЗапроса,0);
	WinHttp.SetRequestHeader("Content-type","application/json;charset=UTF-8");
	WinHttp.SetRequestHeader("Accept","application/json;charset=UTF-8");
	WinHttp.SetRequestHeader("Cache-Control","no-cache");
	Если флОтладка=1 Тогда
		Сообщить(_ПрефикСообщений+"Текст запроса GET "+ТекстЗапроса);
	КонецЕсли;
	WinHttp.Send();
	ТекстОтвета=WinHttp.ResponseText();
	Если WinHttp.Status=200 Тогда
		// имеем ответ такого вида
		// {"uuid":"d5933dc7-d9a5-40cf-ada4-6425c080dfae","data":"SCKSQQSXCVFRHNOZVXQAQOQTPEZFFD"}
		спРезультатРазбора=ТекстJSONВОбъект(ТекстОтвета); // Список из двух значений uuid и data
		Если флОтладка=1 Тогда
			Сообщить(_ПрефикСообщений+"Ответ на запрос "+Лев(ТекстОтвета,400));
			ВывестиРезультатРазбора(спРезультатРазбора);
		КонецЕсли;
		//Возврат спРезультатРазбора;
	Иначе
		Сообщить(_ПрефикСообщений+"Не получилось получить исходные данные для формирования токена !!!","!!!");
		Сообщить("WinHttp.Status="+WinHttp.Status+"    -->   "+РасшифровкаСтатусовОтветовСистемы(WinHttp.Status));
		Сообщить(Лев(ТекстОтвета,400));
		Возврат ПолучитьПустоеЗначение("Справочник.Токены");
	КонецЕсли;
	
	// Подписываем полученные случайные даные
	Если флОтладка=1 Тогда
		Сообщить(_ПрефикСообщений+"Подписываем ""data"" подписью с отпечатком "+Токены.ОтпечатокСертификатаДляПодписи);
	КонецЕсли;
	ПодписанныеДанные=ПодписатьТекст(спРезультатРазбора.Получить("data"),Токены.ОтпечатокСертификатаДляПодписи,0,1); 
	спРезультатРазбора.Установить("data",ПодписанныеДанные); // Меняем значение data на "Подписанные УКЭП зарегистрированного УОТ случайные данные в base64 (электронная подпись присоединенная)"
	Если ПустоеЗначение(ПодписанныеДанные)=1 Тогда
		Сообщить(_ПрефикСообщений+"ошибка при подписании ""data""");
		Возврат ПолучитьПустоеЗначение("Справочник.Токены");
	КонецЕсли;
	
	Если Токены.Объект.Вид()="Фирмы" Тогда
		_omsConnection="";
	Иначе
		_omsConnection="/"+Токены.Объект.ИдентификаторСоединения;
	КонецЕсли;
	
	// Отправляем подписанные случайные данные для получения токена
	// 1.2.2. Получение ключа сессии при единой аутентификации
	WinHttp = Создатьобъект("WinHttp.WinHttpRequest.5.1");
	//ТекстЗапроса=Маркировка_АдресИСМП+"/auth/cert";
	ТекстЗапроса=Маркировка_АдресTrueAPI+"/auth/simpleSignIn"+_o­msConnection;
	WinHttp.Open("POST",ТекстЗапроса,0);
	WinHttp.SetRequestHeader("Content-Type","application/json");
	WinHttp.SetRequestHeader("Accept","application/json");
	//WinHttp.SetRequestHeader("Content-Type","application/json;charset=UTF-8");
	//WinHttp.SetRequestHeader("Accept","application/json;charset=UTF-8");
	//WinHttp.SetRequestHeader("Cache-Control","no-cache");
	//WinHttp.Option(2, "UTF-8");
	//ТелоСообщенияPOST="{""uuid"":"""+спРезультатРазбора.Получить("uuid")+""",""data"":"""+спРезультатРазбора.Получить("data")+"""}";
	ТелоСообщенияPOST=ОбъектВТекстJSON(спРезультатРазбора);
	Если флОтладка=1 Тогда
		Текст=СоздатьОбъект("Текст");
		Текст.ДобавитьСтроку(ТелоСообщенияPOST);
		Текст.Записать(КаталогПользователя()+"ТелоСообщенияPOST.txt");
		Сообщить(_ПрефикСообщений+"Текст запроса POST "+Лев(ТекстЗапроса,400));
		Сообщить("Сохранён файл для просмотра параметров POST "+КаталогПользователя()+"ТелоСообщенияPOST.txt");
	КонецЕсли;
	WinHttp.Send(ТелоСообщенияPOST);
	//WinHttp.Send(ADODB_Stream(ТелоСообщенияPOST));
	
	//Stream = CreateObject("ADODB.Stream");
	//Stream.Open();
	//Stream.loadFromFile(КаталогПользователя()+"ТелоСообщенияPOST.txt");
	//WinHttp.Send(Stream);
	ТекстОтвета=WinHttp.ResponseText();
	Если WinHttp.Status=200 Тогда
		// имеем ответ такого вида
		// {"token":"токен в формате JWT или простой токен для СУЗ"}
		спРезультатРазбора=ТекстJSONВОбъект(ТекстОтвета);
		Если флОтладка=1 Тогда
			Сообщить(_ПрефикСообщений+"Ответ на запрос "+Лев(ТекстОтвета,400));
			ПросмотрПараметра=ТекстОтвета;
			ВывестиРезультатРазбора(спРезультатРазбора);
		КонецЕсли;
		Токены.Токен=спРезультатРазбора.Получить("token");
		Если ПустоеЗначение(_omsConnection)=1 Тогда // Токен ИС МП
			ТокенJWT=РасшифроватьТокенJWT(Токены.Токен); // Данные товкена JWT как строка таблицы значений
			Если ПустоеЗначение(ТокенJWT.exp)=0 Тогда // Наименование нужно вычислять из значения exp - Время окончания срока действия, формат Unix time (number)
				// вот так сдлеано в 1С 8 Наименование = МестноеВремя('19700101' + Цел(РезультатРазбораТокена.exp));
				Токены.Наименование=ИзменитьДатуВремя("19700101 03:00:00",Цел(ТокенJWT.exp)); // 03:00:00 - это часовой пояс Москвы
				Если флОтладка=1 Тогда
					Сообщить("Срок действия: расчет по exp="+Цел(ТокенJWT.exp)+" >> "+Токены.Наименование);
				КонецЕсли;
			Иначе  // ТокенJWT.exp не заполнено, тогда добавим 5 часов к текущему времени
				Токены.Наименование=ИзменитьДатуВремя(Формат(ТекущаяДата(),"ДГГГГММДД")+" "+ТекущееВремя(),10*60*60);
				Если флОтладка=1 Тогда
					Сообщить("Срок действия: добавим 10 часов к текущему времени");
				КонецЕсли;
			КонецЕсли;
			//тзТокены.clientToken=ТокенJWT.jti;
		Иначе // Токен СУЗ
				Токены.Наименование=ИзменитьДатуВремя(Формат(ТекущаяДата(),"ДГГГГММДД")+" "+ТекущееВремя(),10*60*60);
		КонецЕсли;
		Токены.Записать();
	Иначе
		Сообщить(_ПрефикСообщений+"Не получилось получить данные токена !!!","!!!");
		Сообщить("WinHttp.Status="+WinHttp.Status+"    -->   "+РасшифровкаСтатусовОтветовСистемы(WinHttp.Status));
		Сообщить(Лев(ТекстОтвета,400));
		ПросмотрПараметра=ТекстОтвета;
		Возврат ПолучитьПустоеЗначение("Справочник.Токены");
	КонецЕсли;

Показать
58. ЗС1 16.11.21 12:47 Сейчас в теме
О, спасибо!
Тогда еще бы тексты используемых процедур под 7.7:
ТекстJSONВОбъект
ОбъектВТекстJSON
РасшифроватьТокенJWT
ПодписатьТекст
РасшифровкаСтатусовОтветовСистемы
59. Mx00 249 17.11.21 02:25 Сейчас в теме
(58)
ОбъектВТекстJSON

//*******************************************
// RFC 8259 The JavaScript Object Notation (JSON) Data Interchange Format
// в базе есть обработка JSON_Туда_И_Обратно
//
//Соответствие значений JSON значениям 1С
//Запись(Object) - СписокЗначений
//Массив(Array) - ТаблицаЗначений
//Число - Число
//Строка - Строка с поддержкой  \', \", \\, \/, \t, \n, \r, \f, \b; без поддержки \uFFFF.
//Литерал true - "true"
//Литерал false - "false"
//Литерал null - "null"
Функция ОбъектВТекстJSON(Объект,ПереноситьСтроки=0,ВходящийОтступ="",Время="") Экспорт
	//                          ^              ^              ^-время если для даты нужно точно указать время отличное от "00:00:00"
	//                          ^              ^-отступ текущего уровня
	//                          ^-признак формирования удобочитаемого файла (в основном для отладки)
	Если ПереноситьСтроки=1 Тогда
		ТекущийОтступ=РазделительСтрок+ВходящийОтступ;
		Отступ=" ";
		Двоеточие=": ";
	Иначе
		ТекущийОтступ="";
		Отступ="";
		Двоеточие=":";
	КонецЕсли;
	
	СтрокаJSON="";
	Если ТипЗначенияСтр(Объект)="СписокЗначений" Тогда // Object
		СтрокаJSON=СтрокаJSON+"{";
		Для iii=1 По Объект.РазмерСписка() Цикл
			ИмяСвойства="";
			ЗначениеСвойства=Объект.ПолучитьЗначение(iii,ИмяСвойства);
			Если ИмяСвойства="signature" Тогда
			СтрокаJSON=СтрокаJSON+ТекущийОтступ+Отступ+""""+ИмяСвойства+­""""+Двоеточие+""""+ЗначениеСвойства+"""";
				//////Текст=СоздатьОбъект("Текст");
				//////Текст.ДобавитьСтроку(""""+ЗначениеСвойства+"""");
				//////Текст.ДобавитьСтроку(ОбъектВТекстJSON(ЗначениеСвойства,ПереноситьСтроки,ВходящийОтступ+Отступ));
				//////Текст.Записать(КаталогПользователя()+"signature.txt");
			Иначе
			СтрокаJSON=СтрокаJSON+ТекущийОтступ+Отступ+""""+ИмяСвойства+­""""+Двоеточие+ОбъектВТекстJSON(ЗначениеСвойства,ПереноситьСтроки,ВходящийОтступ+Отступ);
			КонецЕсли;
			Если iii<Объект.РазмерСписка() Тогда
				СтрокаJSON=СтрокаJSON+",";
			КонецЕсли;
		КонецЦикла;
		СтрокаJSON=СтрокаJSON+?(Объект.РазмерСписка()>0,ТекущийОтступ,"")+"}";
		
	ИначеЕсли ТипЗначенияСтр(Объект)="ТаблицаЗначений" Тогда // Array
		СтрокаJSON=СтрокаJSON+"[";
		Для iii=1 По Объект.КоличествоСтрок() Цикл
			ЗначениеСтроки=Объект.ПолучитьЗначение(iii,1); // берём данные только из первой колонки !!!
			СтрокаJSON=СтрокаJSON+ТекущийОтступ+Отступ+ОбъектВТекстJSON(ЗначениеСтроки,ПереноситьСтроки,ВходящийОтступ+Отступ);
			Если iii<Объект.КоличествоСтрок() Тогда
				СтрокаJSON=СтрокаJSON+",";
			КонецЕсли;
		КонецЦикла;
		СтрокаJSON=СтрокаJSON+?(Объект.КоличествоСтрок()>0,ТекущийОтступ,"")+"]";
		
	ИначеЕсли ТипЗначенияСтр(Объект)="Строка" Тогда
		Если Объект="true" Тогда
			СтрокаJSON=СтрокаJSON+"true";
		ИначеЕсли Объект="false" Тогда
			СтрокаJSON=СтрокаJSON+"false";
		ИначеЕсли Объект="null" Тогда
			СтрокаJSON=СтрокаJSON+"null";
		////////ИначеЕсли Лев(Объект,5)="<?xml" Тогда
		////////	СтрОбъект=Объект;
		////////	СтрОбъект=СтрЗаменить(СтрОбъект,"\n","");
		////////	СтрокаJSON=СтрокаJSON+""""+СтрОбъект+"""";
		Иначе
			СтрОбъект=Объект;
			СтрОбъект=СтрЗаменить(СтрОбъект,"\", "\\");
			// СтрОбъект=СтрЗаменить(СтрОбъект,"/", "\/"); убрал 09.06.2021 т.к. в КМТ не проходило подписание
			СтрОбъект=СтрЗаменить(СтрОбъект,"""","\""");
			СтрОбъект=СтрЗаменить(СтрОбъект,Симв( 8),"\b");
			СтрОбъект=СтрЗаменить(СтрОбъект,Симв( 9),"\t");
			СтрОбъект=СтрЗаменить(СтрОбъект,Симв(10),"\n");
			СтрОбъект=СтрЗаменить(СтрОбъект,Симв(12),"\f");
			СтрОбъект=СтрЗаменить(СтрОбъект,Симв(13),"\r");
			СтрокаJSON=СтрокаJSON+""""+СтрОбъект+"""";
		КонецЕсли;
		
	ИначеЕсли ТипЗначенияСтр(Объект)="Число" Тогда
		СтрокаJSON=СтрокаJSON+Строка(Объект);
		
	ИначеЕсли ТипЗначенияСтр(Объект)="Дата" Тогда
		СтрОбъект=Формат(Объект,"ДГГГГММДД");
		СтрОбъект=Лев(СтрОбъект,4)+"-"+Сред(СтрОбъект,5,2)+"-"+Прав(СтрОбъект,2);
		Если ПустоеЗначение(Время)=1 Тогда
			Время="00:00:00"+".000Z";
		Иначе
			Если Время="23:59:59" Тогда
				Время=Время+".999Z";
			Иначе
				Время=Время+".000Z";
			КонецЕсли;
		КонецЕсли;
		СтрОбъект=СтрОбъект+"T"+Время;
		СтрокаJSON=СтрокаJSON+""""+СтрОбъект+"""";
	КонецЕсли;
	Возврат СтрокаJSON;
КонецФункции // ОбъектВТекстJSON

Показать
60. Mx00 249 17.11.21 02:26 Сейчас в теме
(58)
ТекстJSONВОбъект


//*********************************************************************************
// RFC 8259 The JavaScript Object Notation (JSON) Data Interchange Format
// в базе есть обработка JSON_Туда_И_Обратно
// в Install есть обработка КОП_JSON.ert там всё 
// есть обработка https://infostart.ru/public/396905/
// здесь используется
// https://forum.mista.ru/topic.php?id=741536
// Функция JSON(Объект, Детализация=0) Экспорт
Функция ОбъектВТекстJSON_(Объект,Детализация=0) Экспорт
	Тип = ТипЗначенияСтр(Объект);
	
	Если Тип = "Справочник" Тогда
		Результат = СоздатьОбъект("Текст");
		Вид = Объект.Вид();
		
		Идентификатор = Метаданные.Справочник(Вид).Идентификатор;
		ПолныйИдентификатор = Метаданные.Справочник(Вид).ПолныйИдентификатор();
		
		Результат.ДобавитьСтроку("{");
		Результат.ДобавитьСтроку(""""+ПолныйИдентификатор+""""+": {");
		
		Код = Объект.Код;
		Результат.ДобавитьСтроку("""Код"": "+""""+Код+""",");
		Наименование = Объект.Наименование;
		Результат.ДобавитьСтроку("""Наименование"": "+""""+Наименование+"""");
		
		Если Детализация>=1 Тогда
			Результат.ДобавитьСтроку(",");
			
			КоличествоРеквизитов = Метаданные.Справочник(Вид).Реквизит();
			Для НомерРеквизита=1 По КоличествоРеквизитов Цикл
				Реквизит = Метаданные.Справочник(Вид).Реквизит(НомерРеквизита);
				РеквизитИдентификатор = Реквизит.Идентификатор;
				Результат.ДобавитьСтроку(""""+РеквизитИдентификатор+""""+": ");
				РеквизитЗначение = Объект.ПолучитьАтрибут(РеквизитИдентификатор);
				
				лТекстРеквизит = ОбъектВТекстJSON(РеквизитЗначение, Детализация-1);
				
				КоличествоСтрокРеквизит = лТекстРеквизит.КоличествоСтрок();
				Для НомерСтрокиРеквизит=1 По КоличествоСтрокРеквизит Цикл
					Результат.ДобавитьСтроку(лТекстРеквизит.ПолучитьСтроку(НомерСтрокиРеквизит));
				КонецЦикла;
				
				Если НомерРеквизита<КоличествоРеквизитов Тогда
					Результат.ДобавитьСтроку(",");
				Иначе
					
				КонецЕсли;
			КонецЦикла;
		КонецЕсли;
		
		Результат.ДобавитьСтроку("}");
		Результат.ДобавитьСтроку("}");
		
		Возврат Результат;
	ИначеЕсли (Тип = "Документ") Тогда
		// еще не наваяно
		
	ИначеЕсли (Тип = "ТаблицаЗначений") ИЛИ (Тип = "СписокЗначений") Тогда
		// еще не наваяно
		
	ИначеЕсли Тип = "Строка" Тогда
		Если Объект = "true" Тогда
			_Рез="true";
		ИначеЕсли Объект = "false" Тогда
			_Рез="false";
		ИначеЕсли Объект = "null" Тогда
			_Рез="null";
		Иначе
			_Рез = СокрЛП(Объект);
			_Рез = СтрЗаменить(_Рез, "\",				"\\");
			_Рез = СтрЗаменить(_Рез, "/",				"\/");
			_Рез = СтрЗаменить(_Рез, """",				"\""");
			_Рез = СтрЗаменить(_Рез, Симв(8),			"\b"); // Символ Backspace
			_Рез = СтрЗаменить(_Рез, Симв(9),			"\t"); // СимволТабуляции
			_Рез = СтрЗаменить(_Рез, Симв(10),			"\n"); // перевод строки
			_Рез = СтрЗаменить(_Рез, Симв(12),			"\f"); // перевод страницы
			_Рез = СтрЗаменить(_Рез, Симв(13),			"\r"); // возврат каретки
			_Рез = """" + _Рез + """";
			Возврат _Рез;
		КонецЕсли;
	ИначеЕсли Тип = "Число" Тогда
		//Результат = СоздатьОбъект("Текст");
		//Результат.ДобавитьСтроку(Объект);
		//Возврат Результат;
		Возврат Строка(Объект);
	ИначеЕсли Тип = "Дата" Тогда
		//Результат = СоздатьОбъект("Текст");
		Если ПустоеЗначение(Детализация)=1 Тогда
			_Время="00:00:00"+".000Z";
		Иначе
			Если Детализация="23:59:59" Тогда
				_Время=Детализация+".999Z";
			Иначе
				_Время=Детализация+".000Z";
			КонецЕсли;
		КонецЕсли;
		_Рез=ОбъектВТекстJSON(Формат(Объект,"ДГГГГ-ММ-ДД")+"T"+_Время);
		//Результат.ДобавитьСтроку();
		Возврат _Рез;
	Иначе
		//Результат = СоздатьОбъект("Текст");
		//Результат.ДобавитьСтроку(ОбъектВТекстJSON(Строка(Объект)));
		//Возврат Результат;
		Возврат Строка(Объект);
	КонецЕсли;
КонецФункции // ОбъектВТекстJSON
Показать
62. ЗС1 17.11.21 12:44 Сейчас в теме
(60)
Функция ОбъектВТекстJSON_(Объект,Детализация=0) Экспорт


Это не ТекстJSONВОбъект

И осталось самое мало - текст функции ПодписатьТекст )))
63. Mx00 249 17.11.21 13:19 Сейчас в теме
(62) ПодписатьТекст - смотри сообщение 57
64. Commander 27.11.21 20:26 Сейчас в теме
(63) вообще не вижу сообщения 57... (упс, увидел)
65. Commander 27.11.21 20:30 Сейчас в теме
(60) можете выложить функцию ТекстJSONВОбъект ? В данном ответе не она...
61. Mx00 249 17.11.21 02:29 Сейчас в теме
(58)
РасшифроватьТокенJWT

//******************************************************************************
Функция РасшифроватьТокенJWT(Токен) Экспорт
	ТокенJWT=СоздатьОбъект("ТаблицаЗначений");
	//ТокенJWT.НоваяКолонка("user_status");			// текущий статус пользователя в системе ИС МП
	//ТокенJWT.НоваяКолонка("inn");					// ИНН
	//ТокенJWT.НоваяКолонка("id");					// Регистрационный номер участника в ИС МП
	//ТокенJWT.НоваяКолонка("exp");					// Время окончания срока действия, формат Unix time (number)
	//ТокенJWT.НоваяКолонка("organisation_status");	// Статус регистрации участника в ИС МП
	//ТокенJWT.НоваяКолонка("client_id");				// Служебный атрибут ИС МП
	//ТокенJWT.НоваяКолонка("jti");					// Надеюсь, что это clientToken
	ТокенJWT.НоваяСтрока();
	
	ЧастиТокена = СтрЗаменить(Токен,".",РазделительСтрок);
	Если СтрКоличествоСтрок(ЧастиТокена) <> 3 Тогда
		Сообщить("Токен не соответствует формату JWT");
		Возврат 0;
	КонецЕсли;
	
	ДанныеТокена = base64_decode(СтрПолучитьСтроку(ЧастиТокена,2));
	
	спРезультатРазбора=ТекстJSONВОбъект(ДанныеТокена);
	
	Для iii=1 По спРезультатРазбора.РазмерСписка() Цикл
		ПараметрJWT="";
		ЗначениеJWT=спРезультатРазбора.ПолучитьЗначение(iii,ПараметрJWT);
		ТокенJWT.НоваяКолонка(ПараметрJWT);
		ТокенJWT.УстановитьЗначение(1,ПараметрJWT,ЗначениеJWT);
		Если флОтладка=1 Тогда
			Сообщить("ТокенJWT "+ПараметрJWT+": "+Преобразовать_из_UTF8(ЗначениеJWT));
		КонецЕсли;
	КонецЦикла;
	Если флОтладка=1 Тогда
		//ыыы=1;ТокенJWT.ВыбратьСтроку(iii); // вывод результата разбора
	КонецЕсли;
	Возврат ТокенJWT;
КонецФункции // РасшифроватьТокенJWT
Показать
57. Mx00 249 16.11.21 00:20 Сейчас в теме
(55) Подписание с помощью утилиты CryptCP.x64.exe
это своего рода "костыль", но работает
Функция ПодписатьТекст(Знач ТекстДляПодписи,ОтпечатокСертификата,ОткрепленнаяПодпись=1,ВКодировкеBase64=1)
	ПапкаДляПодписываемыхФайлов=КаталогПользователя();
	РезультатПодписания="";
	// Сначала сохраним ТекстДляПодписи
	ФайлДляПодписи=ПапкаДляПодписываемыхФайлов+"TextForSigning.txt";
	Текст=СоздатьОбъект("Текст");
	Текст.ДобавитьСтроку(ТекстДляПодписи);
	Текст.Записать(ФайлДляПодписи);
	ФайлГотовойПодписи=ПапкаДляПодписываемыхФайлов+"SigningResul­t.txt";
	Если ФС.СуществуетФайл(ФайлГотовойПодписи)=1 Тогда
		ФС.УдалитьФайл(ФайлГотовойПодписи);
	КонецЕсли;
	
	// Определим параметры запуска
	ПутьCryptCP="C:\Program Files\Crypto Pro\CSP";
	WshShell=СоздатьОбъект("WScript.Shell");
	СтрокаЗапускаCryptCP="CryptCP.x64.exe -sign -addchain"+?(ОткрепленнаяПодпись=1," -detached","")+?(ВКодировкеBase64=1,"","-der")+" -thumbprint "+ОтпечатокСертификата+" """+ФайлДляПодписи+""" """+ФайлГотовойПодписи+"""";
	WshShell_CurrentDirectory=WshShell.CurrentDirectory; // Сохраним путь текущего каталога
	WshShell.CurrentDirectory=ПутьCryptCP;               // Установим текущий каталог ПутьCryptCP
	WshShell.Run(СтрокаЗапускаCryptCP,0,1);              // Выполним скрипт подписания
	WshShell.CurrentDirectory=WshShell_CurrentDirectory; // Установим текущий каталог на первоначальный
	Если ФС.СуществуетФайл(ФайлГотовойПодписи)=1 Тогда
		Текст.Открыть(ФайлГотовойПодписи);
		Для iii=1 По Текст.КоличествоСтрок() Цикл
			РезультатПодписания=РезультатПодписания+СокрЛП(Текст.ПолучитьСтроку(iii));
		КонецЦикла;
		РезультатПодписания=СокрЛП(РезультатПодписания);
	КонецЕсли;
	Если ПустоеЗначение(РезультатПодписания)=1 Тогда
		Сообщить("Ошибка в процедуре ПодписатьТекстCryptCP при подписании текста");
	КонецЕсли;
	Возврат РезультатПодписания; // Подпись в формате Base64
КонецФункции // ПодписатьТекстCryptCP

Показать
66. SeTIrk 15.08.22 12:17 Сейчас в теме
(57)
Подписание с помощью утилиты CryptCP.x64.exe

Вы случайно с csptest не пробовали делать? Есть ощущение что выходной файл не содержит исходного вложения файла, по крайней мере то что получаю через cades плагин, и csptest отличается. На машине стоит csp4, и пока обновлять не планируют.
csptest -sfsign -sign -in C:\motp\tosign.txt -out C:\motp\signed.txt -my "thumbprint" -detached -base64 –add
67. Mx00 249 15.08.22 22:55 Сейчас в теме
(66)
csptest
- это тестовая утилита, она не всё может сделать, пришлось перейти на CryptCP.x64.exe
68. SeTIrk 16.08.22 04:50 Сейчас в теме
(67) С этой частью разобрался. Cryptcp с 4 версии в свободном доступе, качается со страницы загрузки csp, вроде как не нужна лицензия.
25. user1512717 22.12.20 13:03 Сейчас в теме
Добрый день!

Мы новички в этой сфере. Можете посоветовать у кого можно получить "платную консультацию" по работе с этим API?
Возможно с Вами можем пообщаться.

Будем благодарны за любую помощь.

Спасибо!

Вероника
jasperss; +1 Ответить
26. user635667 16.03.21 06:13 Сейчас в теме
А можно при помощи этой штуки скачать все товары и ШК от них?
На сайте ЧЗ в разделе Табак в разделе Коды маркировки есть столбик Товар. Я бы экспортировал в Эксельку, но там постранично, а как пропарсить я не знаю.
Прикрепленные файлы:
38. oskarsan 01.06.21 10:49 Сейчас в теме
Подскажите, пожалуйста: делаю get запрос, получаю уид и данные, данные подписываю через сайт криптопро. отправляю уид и подписанные данные для получения токена, возвращается ошибка "Ошибка. Код ответа 500
UUID не найден в хранилище ключей. UUID = ". В чем может быть проблема?
и этот токен будет действовать только 10часов или до окончания сертификата?
39. oskarsan 06.06.21 14:26 Сейчас в теме
(38) Подписал через 1C - заработало, так и не понял в чем проблема была.
69. SeTIrk 16.08.22 08:28 Сейчас в теме
Если вдруг кому понадобится рабочий код для получения токена на powershell
PowerShell
Exorcist_ru; +1 Ответить
70. пользователь 23.08.22 13:56
Сообщение было скрыто модератором.
...
Оставьте свое сообщение