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

07.07.21

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

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

Скачать файлы

Наименование Файл Версия Размер
Внешняя библиотека (*.dll) шифрование по алгоритму RSA:
.dll 5,50Kb
20
.dll 5,50Kb 20 Скачать

При постановки задачи перерыл весь Интернет, но так и не нашел обработки по шифрованию заданной строки по алгоритму 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 открытый ключ публичный

См. также

Медиадисплей. Рекламный информационный монитор для покупателя.

Разработка внешних компонент POS терминал Рабочее место Розничная торговля Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Рестораны, кафе и фаст-фуд Реклама, PR и маркетинг Управленческий учет Платные (руб)

Монитор покупателя может отображать текущую покупку на кассовом месте, показывать видеорекламу, баннеры, во время простоя разворачивать рекламу на весь экран. Можно использовать в качестве графического меню-борда в кафе и видеовывески. Управление выводом на телевизор через hdmi-приставку на базе Windows или Android. В качестве устройства отображения можно использовать Android-планшеты, фоторамки с Android, монитор любого Windows-компьютера, доступного по сети. Настраивается ЛЮБОЙ ДИЗАЙН экрана!

16800 руб.

30.05.2017    52115    34    69    

43

Внешняя компонента для сканирования (замена TWAIN-компоненты БСП) (Native Win 32/64)

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

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

2400 руб.

12.05.2020    26250    131    99    

83

Внешняя компонента для подключения 1С к телефонии Asterisk

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

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

2400 руб.

04.05.2018    44985    117    64    

60

Внешняя компонента печати PDF (Native Win 32/64)

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

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

1500 руб.

17.09.2018    35088    104    123    

111

Мастер создания внешних компонент 1С (технология COM) для DELPHI 6/7/8/2005/2006/2007/2008/2010/XE/XE2/XE3

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

Средство для сверхбыстрой разработки внешних компонент 1С:Предприятия 7.7 и 8 по технологии COM на всех версиях DELPHI, начиная с 6.

2000 руб.

28.03.2013    54005    35    14    

68

QR-код с логотипом компании (обычная и управляемая форма)

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

Как известно, стремление сделать свою рекламную продукцию запоминающейся и выделяющейся — верный путь к успеху. Сегодня, мы поговорим с вами о том, что можно сделать с обычным черно-белым QR-кодом, чтобы он стал более живым и привлекательным. Если вам не терпится попробовать сделать QR-код с логотипом компании, то эта обработка для вас!

2400 руб.

22.06.2016    30844    4    4    

8

Внешняя компонента 1С и С++. Продолжаем разговор.

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

А давайте запилим 8.3.26 до релиза, или оповещение с сервера...

19.02.2024    4044    starik-2005    28    

52

Внешние компоненты 1С и язык C++

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

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

26.01.2024    4787    starik-2005    32    

39
Отзывы
1. user955631 08.07.21 08:10 Сейчас в теме
Спасибо, все работает! Действительно, все обработки на этом сайте по шифрованию РСА только генерируют свои ключи, и передать свой открытый ключ никак нельзя. Эта - единственная в своем роде работающая бибилиотека.
Остальные комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. user955631 08.07.21 08:10 Сейчас в теме
Спасибо, все работает! Действительно, все обработки на этом сайте по шифрованию РСА только генерируют свои ключи, и передать свой открытый ключ никак нельзя. Эта - единственная в своем роде работающая бибилиотека.
6. itserve 30 09.07.21 08:15 Сейчас в теме
2. SerVer1C 749 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 749 08.07.21 16:15 Сейчас в теме
(3) Ага ) А для кириллицы размер исходного текста потребуется уменьшить еще вдвое. Так для каких целей можно применять сто-буквенное rsa-шифрование в 1с? шифровать наименования справочников?
5. itserve 30 08.07.21 17:14 Сейчас в теме
(4)Мне оно потребовалось для обмена данными с банком. На Инфостарт куча подобных обработок, но ни в одну из них нельзя передать свой ключ. Если подобных обработок так много - значит, спрос на них есть.
22. uno-c 235 03.06.23 00:30 Сейчас в теме
(3) Ограничение размера RSA-шифруемых данных связано с длиной ключа не из-за стоимости вычислений. Шифрование RSA - это возведение в степень по модулю открытого ключа. То есть зашифрованные данные - это число-остаток от деления на число-открытый ключ. Информацию длиннее открытого ключа в принципе не расшифруешь независимо от вычислительных ресурсов, поэтому ее и нет смысла шифровать. Условно говоря, и для триллиона и для тысячи остаток от деления на 999 будет меньше 999. Что у тебя было до деления невозможно сказать, если нет ограничения, что до деления было число меньше 999.
7. kite2 58 02.02.22 18:40 Сейчас в теме
В свое время делал подобные вещи.
Рекомендую книгу
«ОСНОВЫ ПРОГРАММИРОВАНИЯ» В.М. Бондарев, В.И. Рублинецкий и Е.Г. Качко

P.S. Правда я так и не понял, доказана теорема Ферма или нет?
10. kite2 58 03.02.22 08:01 Сейчас в теме
Плюс задача на сообразительность. Какие последствия будут, если теорема Ферма для больших чисел ошибочна?
11. kite2 58 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) Обратите внимание на версию НетФреймворк, которая у вас установлена.

Тестировал данную библиотеку не только на сервере, но и на локальном компьютере.
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 235 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>)
20. Sonic_seb 2 18.03.22 09:05 Сейчас в теме
Серьезно бесплатная?:) а как же 10 стартмани или это не деньги и вы их не получили?
21. itserve 30 18.03.22 10:28 Сейчас в теме
(20) Во-первых - это не деньги. И даже не криптовалюта. Ими нельзя расплатиться нигде, кроме Инфостарт.
Так что я не получил от вас ни копейки. Или вы работаете в организации, которая выплачивает вам зп Стартмани?
Оставьте свое сообщение