Шифрование по алгоритму RSA. Внешняя библиотека (*.dll)

07.07.21

Разработка - Разработка внешних компонент

Внешняя библиотека для шифрования данных в 1С по алгоритму RSA открытым ключом. Открытый ключ задаем сами, и передаем в качестве параметра.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Внешняя библиотека (*.dll) шифрование по алгоритму RSA:
.dll 5,50Kb
24
24 Скачать (10 SM) Купить за 4 550 руб.

При постановки задачи перерыл весь Интернет, но так и не нашел обработки по шифрованию заданной строки по алгоритму RSA с заданным ключом.

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

Данная обработка на входе получает исходную строку для шифрования и открытый ключ в виде строки.

На выходе получаем зашифрованную строку.

Проверял работоспособность на сайте 8gwifi.org/RSAFunctionality?keysize=2048

Порядок действий:

1) Скачиваем библиотеку 

2) Регистрируем ее

Для регистрации

1. Запускаем командную строку от имени Администратора

2. Копируем RSAEncoder.dll в папку С:\RSAEncoder\ 

3. Пишем в командной строке C:\Windows\Microsoft.NET\Framework64\v4.0.30319\RegAsm.exe "С:\RSAEncoder\RSAEncoder.dll" /codebase 

3) Вызываем в 1С
    РСАЭнкодер = Новый COMОбъект("RSAEncoder.RSAEncodeManager");
    ЗашифрованнаяСтрока = РСАЭнкодер.Encode(КодируемаяСтрока, ПубличныйКлюч);

Данная библиотека тестировалась на различных конфигурациях платформы версии 1С 8.3.16 и 8.3.18.

На более старых платформах будет работать без проблем.

шифрование RSA открытый ключ публичный

См. также

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента в виде библиотеки (.dll файл), позволяющая посылать команды и получать ответы по протоколу WebSocket из 1С. Компонента работает только на стороне "клиента".

4440 руб.

22.06.2020    18124    18    33    

22

Разработка внешних компонент Телефония, SIP Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Внешняя компонента выполнена по технологии Native API для 1С 8.х, обеспечивает доступ к программным АТС Asterisk (FreePBX, Elastix) через AMI интерфейс. Через него можно управлять многими функциями Asterisk (определение номеров, перевод звонков, набор телефона и т. д.)

2400 руб.

04.05.2018    46784    122    66    

66

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

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

3000 руб.

12.05.2020    28220    138    100    

90

Разработка внешних компонент Программист Платформа 1С v8.3 Платформа 1C v8.2 Платные (руб)

Внешняя компонента, позволяющая посылать команды и получать ответы по GraphQL протоколу из 1С.Может быть использована при интеграции. В 1С работает на стороне "клиента".

4600 руб.

27.06.2023    3394    2    0    

4

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента позволяет печатать PDF файлы непосредственно из 1С, не используя при этом сторонних программ. Прекрасно работает на сервере, тонком клиенте и веб-клиенте. Основана на проекте PDFium из состава проекта Chromium/Chrome

1500 руб.

17.09.2018    36476    113    127    

114

Разработка внешних компонент Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Некоторые практические аспекты создания внешних компонент на языке С++ для платформы 1С 8.3++.

26.01.2024    6765    starik-2005    32    

44

Инструментарий разработчика Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример взаимодействия 1С с Apach Kafka посредством внешней компоненты, разработанной на основе официальной библиотеки librdkafka (the Apache Kafka C/C++ client library).

22.11.2023    4354    86    ivan1703    26    

41
Отзывы
1. user955631 08.07.21 08:10 Сейчас в теме
Спасибо, все работает! Действительно, все обработки на этом сайте по шифрованию РСА только генерируют свои ключи, и передать свой открытый ключ никак нельзя. Эта - единственная в своем роде работающая бибилиотека.
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. user955631 08.07.21 08:10 Сейчас в теме
Спасибо, все работает! Действительно, все обработки на этом сайте по шифрованию РСА только генерируют свои ключи, и передать свой открытый ключ никак нельзя. Эта - единственная в своем роде работающая бибилиотека.
6. itserve 30 09.07.21 08:15 Сейчас в теме
2. SerVer1C 815 08.07.21 15:34 Сейчас в теме
а если я на вход подам длинный текст (длиннее размера ключа) ?
3. itserve 30 08.07.21 15:56 Сейчас в теме
(2) Кодируемая строка не должна быть длиннее 245 символов. Сайт 8gwifi.org/RSAFunctionality?keysize=2048 вернет такую же ошибку, если попытаетесь зашифровать на нем более длинную строку.

Шифрование RSA предназначено только для небольших объемов данных, объем данных, который вы можете зашифровать, зависит от размера используемого вами ключа, например, для 1024-битных ключей RSA, вы можете зашифровать не более 117 байт, с ключом 2048 RSA вы можете зашифровать 245 байт.

Для этого есть веская причина: асимметричное шифрование является дорогостоящим с точки зрения вычислений. Если вы хотите зашифровать большие объемы данных, вам следует использовать симметричное шифрование.
4. SerVer1C 815 08.07.21 16:15 Сейчас в теме
(3) Ага ) А для кириллицы размер исходного текста потребуется уменьшить еще вдвое. Так для каких целей можно применять сто-буквенное rsa-шифрование в 1с? шифровать наименования справочников?
5. itserve 30 08.07.21 17:14 Сейчас в теме
(4)Мне оно потребовалось для обмена данными с банком. На Инфостарт куча подобных обработок, но ни в одну из них нельзя передать свой ключ. Если подобных обработок так много - значит, спрос на них есть.
22. uno-c 264 03.06.23 00:30 Сейчас в теме
(3) Ограничение размера RSA-шифруемых данных связано с длиной ключа не из-за стоимости вычислений. Шифрование RSA - это возведение в степень по модулю открытого ключа. То есть зашифрованные данные - это число-остаток от деления на число-открытый ключ. Информацию длиннее открытого ключа в принципе не расшифруешь независимо от вычислительных ресурсов, поэтому ее и нет смысла шифровать. Условно говоря, и для триллиона и для тысячи остаток от деления на 999 будет меньше 999. Что у тебя было до деления невозможно сказать, если нет ограничения, что до деления было число меньше 999.
7. kite2 61 02.02.22 18:40 Сейчас в теме
В свое время делал подобные вещи.
Рекомендую книгу
«ОСНОВЫ ПРОГРАММИРОВАНИЯ» В.М. Бондарев, В.И. Рублинецкий и Е.Г. Качко

P.S. Правда я так и не понял, доказана теорема Ферма или нет?
27. METAL 299 17.10.24 18:26 Сейчас в теме
(9) Не открывается, к сожалению... Это из книги, упомянутой выше?
10. kite2 61 03.02.22 08:01 Сейчас в теме
Плюс задача на сообразительность. Какие последствия будут, если теорема Ферма для больших чисел ошибочна?
11. kite2 61 03.02.22 08:06 Сейчас в теме
Плюс задача на сообразительность. Что будет, если теорема Ферма для больших чисел ошибочна?

Подсказка:

Прочитайте 2 слова быстро, не задумываясь о том, что вы читаете

1. Мама мылы раму
2. Мма мыла раму
12. volga-autom 01.03.22 09:44 Сейчас в теме
Здравствуйте! Поставлена задача интегрировать яндекс навигатор с мобильным приложением. Есть инструкция по шифрованию строки которая передаются на мобильный клиент.
https://yandex.ru/dev/yandex-apps-launch/navigator/doc/concepts/navigator-commercial-use-signature.html

Получил ключ от яндекс навигатора. Подойдет ли данная обработка для этой задачи.???

Спасибо
15. itserve 30 17.03.22 15:30 Сейчас в теме
(12)Нужно вникать и разбираться) Это время, поэтому консультация будет платной 3 500 руб. в час
13. Sonic_seb 2 17.03.22 13:45 Сейчас в теме
C:\Windows\Microsoft.NET\Framework64\v4.0.30319>RegAsm.exe "C:\RSAEncoder\RSAEncoder.dll" /codebase
Microsoft .NET Framework Assembly Registration Utility 4.7.3062.0
для Microsoft .NET Framework 4.7.3062.0
c Корпорация Майкрософт (Microsoft Corporation). Все права защищены.

RegAsm : warning RA0000 : Регистрация неподписанной сборки с использованием параметра /codebase может вызвать конфликт данной сборки с другими приложениями, которые могут быть установлены на том же компьютере. Параметр /codebase предназначен только для подписанных сборок. Присвойте сборке строгое имя и повторите регистрацию.
Типы зарегистрированы успешно

{ОбщийМодуль.TinkoffBank.Модуль(971)}: Ошибка при вызове конструктора (COMОбъект): -2147221164(0x80040154): Класс не зарегистрирован
Произошла ошибка: Ошибка формирования подписи запроса, Подробности: Возникла ошибка при формировании подписи запроса
14. itserve 30 17.03.22 15:23 Сейчас в теме
(13)
RegAsm : warning RA0000 : Регистрация неподписанной сборки с использованием параметра /codebase может вызвать конфликт данной сборки с другими приложениями, которые могут быть установлены на том же компьютере.

1) Запускать КС нужно от Админа
2) Обратите внимание на версию НетФреймворк, которая у вас установлена.

Тестировал данную библиотеку не только на сервере, но и на локальном компьютере.
24. METAL 299 16.10.24 21:44 Сейчас в теме
(14) Не удалось найти причину ошибки при регистрации
RegAsm : error RA0000 : Данный формат пути не поддерживается.
?
У меня та же проблема
16. Sonic_seb 2 17.03.22 15:47 Сейчас в теме
1. Запускаем от Админа
2. Установлено НетФреймворк 3.5 и 4.6
17. пользователь 17.03.22 17:12
Сообщение было скрыто модератором.
...
18. Sonic_seb 2 17.03.22 17:34 Сейчас в теме
Т.е. мы купили, она не устраивает нас, потому что не работает. Вы подсказать не можете....Интересно...
19. itserve 30 17.03.22 20:09 Сейчас в теме
(18)я уже подсказал выше. Все зависит от версии виндовс и десятков других факторов, в том числе - регулярно ли Вы обновляема операционную систему. Нужно разбираться. Библиотека бесплатная - вы за неё не заплатили ни копейки. Хотите чтобы я помог в конкретно вашем случае - 3 500 руб в час. Бесплатно работать никто не станет. Торопитесь - с понедельника будет уже 5 000 в час.
23. uno-c 264 08.06.23 09:28 Сейчас в теме
(18) Можно было не "покупать". При шифровании можно обойтись и без dll-ки из этой публикации, поскольку .Net сам предоставляет Com-интерфейс, которым можно воспользоваться из 1С.
&НаСервере
Процедура ПробаШифровать()
	ХМЛОткрытогоКлюча = "<RSAKeyValue><Modulus>0YU4h4rlAoVrimOmbGq0f3BYbRGFiMWMDIB9W­pzWFxms6o3/fyJrSAdB9Aa/bTuqGxSO+78ldLvuOM4AzOQl/CcRNZXfdwtgv­t3Ss1Vx2n9TryvYsBhjq2MAXIKnhiSl1IEOQNLfpUehAXediN53ZMMtOwHjB­lDwE2xznzFJ3Wd5CunMTtM01mxsKjYXaFJdnX/NuxLkypE8Oz3YHhKN+a7nX­Y5xhtmSRf2dgD1v4ItWan5TWBL4yqya57Sr9ye7TXUHcN7pwVBo+NAIE9iTV­CJwQsWpF7rjwkxtjW6FtXmiYlpnFYcsYX58eTGU5EcHxIuEYu1MD21DvydOb­NjCLQ==</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>";
	КрПровайдер = Новый COMОбъект("System.Security.Cryptography.RSACryptoServiceProvider");
	КрПровайдер.FromXmlString(ХМЛОткрытогоКлюча);
	ТекстДляШифрования = "Test 111";
	ComSafeArrayДляШифрования = SafeИзДвоичных(ПолучитьДвоичныеДанныеИзСтроки(ТекстДляШифрования));
	ComSafeArrayЗашифрован = КрПровайдер.Encrypt(ComSafeArrayДляШифрования, Истина);
	ЗашифрованоБейс64 = Base64Строка(ДвоичныеИзSafe(ComSafeArrayЗашифрован));
КонецПроцедуры

Функция SafeИзДвоичных(ДвоичныеДанные)
	Буфер = ПолучитьБуферДвоичныхДанныхИзДвоичныхДанных(ДвоичныеДанные);
	Байтов = Буфер.Размер;
	COMSafeArray = Новый COMSafeArray("VT_UI1", Байтов);//однобайтовый без знака
	Для сч = 0 по Байтов-1 Цикл
		COMSafeArray.SetValue(сч, Буфер.Получить(сч));
	КонецЦикла;
	Возврат COMSafeArray;
КонецФункции

Функция ДвоичныеИзSafe(SafeArrayBin) 
	Буфер = Новый БуферДвоичныхДанных(SafeArrayBin.GetLength());
	Для сч = 0 по SafeArrayBin.GetUpperBound() Цикл
		Буфер.Установить(сч, SafeArrayBin.GetValue(сч));
	КонецЦикла;
	Возврат ПолучитьДвоичныеДанныеИзБуфераДвоичныхДанных(Буфер);
КонецФункции
Показать

ЗашифрованоБейс64
"wzTXlPvECqsgZK1BCrWiXpRqrmLhUI6V1CJpc19tRPKlkc6wo4D8ESjI3zf­+DvU/
YFyYW4b566Igq7DWPI6a+jm7qg91UL8YzacGZQzsfYYk06gXliV3//Dn3q0O­9n3O
ecbkhwPmrmttvmvVjSH/f8FATEMrnCPtCcg/F5w7u8fAeezxBNr4Aj6YU4O6­ZGKq
vIfOqWE1FvBTudLDqDBo+V+QUmG/MBpJ6FAvow1rVHTJcJp/oD5ZcnQHbTgy­dzBC
qf/eAMP0inJt4W3kK/4XusP6bdCLINrIuPwO0omtbsX5fExUbwkHlm+Sud81­xETb
cUeZm5bx5CsEoR1u6PmN4g=="
Строка

Остается только открытий ключ из PEM-формата (там где "---BEGIN PUBLIC KEY--- ...") перевести в XML-формат (там где <RSAKeyValue><Modulus>...</Modulus><Exponent>...</Exponent></RSAKeyValue>)
METAL; itserve; SerVer1C; kamisov; +4 Ответить
26. METAL 299 16.10.24 22:14 Сейчас в теме
(23)
Остается только открытий ключ из PEM-формата (там где "---BEGIN PUBLIC KEY--- ...") перевести в XML-формат (там где ......)

А как это сделать? Надо ---BEGIN PUBLIC KEY--- с суффиксом убирать? Надо ли в base64 переводить?
20. Sonic_seb 2 18.03.22 09:05 Сейчас в теме
Серьезно бесплатная?:) а как же 10 стартмани или это не деньги и вы их не получили?
21. itserve 30 18.03.22 10:28 Сейчас в теме
(20) Во-первых - это не деньги. И даже не криптовалюта. Ими нельзя расплатиться нигде, кроме Инфостарт.
Так что я не получил от вас ни копейки. Или вы работаете в организации, которая выплачивает вам зп Стартмани?
25. METAL 299 16.10.24 21:53 Сейчас в теме
(21) Ну.. Стартмани же можно продать на бирже. Да, вывод на карту требует некоторых усилий, но всё же

Плюс за рубли продаётся обработка 4550 руб текущая цена, как вижу на странице выше, рядом с ценой в стартмани..

Хотелось бы получить какой-то комментарий... Может есть какие-то идеи почему не регистрируется? Что попробовать? Win10 x64 , делаю всё строго по инструкции
Оставьте свое сообщение