Switch to English?
Yes
Переключитись на українську?
Так
Переключиться на русскую?
Да
Przełączyć się na polską?
Tak
Post your project for free and start getting offers from freelance performers within minutes after posting!

Функция шифрования на языке “С” для платы Ардуино.


  1. 852    14  0
    2 days20 USD

    Здравствуйте.
    Могу выполнить данную работу.
    --
    Дополнительный текст.

  2. 5 more hidden bids
    1 bid hidden
  • Profile deleted
    2 September 2019, 11:46 |

    А есть мысли по поводу того, как шифровать? Вы хоть намекните про какие-нибудь рамки, ограничения, может нужен стндарт какой-то...

  • Yura Palaha
    2 September 2019, 17:18 |

    AES вполне устроит

  • Aleksandr Aleksandr
    2 September 2019, 12:11 |

    контроллер можно залочить от чтения и никто ваш eeprom не прочтет.

  • Yura Palaha
    2 September 2019, 17:19 |

    Хороший вариант. Что будет стоить такая работа ?

  • Profile deleted
    3 September 2019, 13:01 |

    Скорее всего, имеется в виду подход с установкой lock bits (см., напр., обсуждение). Но, по-моему, это действие обратимо при наличии необходимого оборудования (его стоимость в пределах $50).

  • Yura Palaha
    4 September 2019, 11:09 |

    Спасибо. За ссылку. Полезно.


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

  • Sergey Mironov
    2 September 2019, 17:33 |

    Не совсем понятно, что надо получить на выходе.
    Если код в МК должен читать ключ прежде, чем он запустится, то никакого способа его защитить нет. Потому что ключ у вас храниться в EEPROM. Если поставить защиту на запись, чтобы злоумышленник не смог поменять ваш ключ на свой, то ничто не мешает ему просто тупо скопировать содержимое EEPROM на другую ардуинку.

  • Aleksandr L.
    3 September 2019, 23:54 |

    100% согласен. Шифрация  эта до Фени, ведь функция дешифрации будет на томже контроллере.
    Взлом займет минут 30, было б там чего важного.

  • Yura Palaha
    4 September 2019, 11:16 |

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

  • Aleksandr L.
    4 September 2019, 11:21 |

    Сами себе противоречите, если программа защищена Битом на чтение - и считать данные "как вы уверяете невозможно" - зачем их шифровать?

    Снять бит на чтения - дело 2 минут.

  • Aleksandr L.
    4 September 2019, 11:26 |

    А не вру)) высоковольтным программатором не получается снять блокировку - беру слова обратно.

  • Yura Palaha
    4 September 2019, 11:36 |

    Так все же, если мк защищен битом от чтения с него ПО, есть ли возможность прочесть содержимое мк чем либо (за адекватные деньги) ? 


    Кроме конечно бекдоров которые производитель может вставлять в свои мк.

  • Yura Palaha
    4 September 2019, 11:37 |

    >> Если он защищен битом

    Потому что данные в другой памяти, т.е. в отдельной с.

  • Aleksandr L.
    4 September 2019, 12:15 |

    FLASH память программы не получится считать - так что все нормально это я напутал. Спец  программатором для atmel овских чипов можно только сбросить фьюзы или затереть флешпамять.

  • Yura Palaha
    4 September 2019, 12:34 |

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

  • Aleksandr L.
    4 September 2019, 12:16 |

    ключи у вас во флешпамяти, данные в еепром - все ок.


  • Yura Palaha
    4 September 2019, 12:34 |

    )

  • Ihor Lozovsky
    3 September 2019, 6:24 |

    Лучше это делать не так.

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

  • Profile deleted
    3 September 2019, 12:57 |

    Теорию-то вы изложили верно, но вообще не факт, что заказчик хранит в EEPROM "пароли для входа". Там могут храниться данные, которые нужны для работы зашитого алгоритма - естественно, "хеши" от них не подойдут.

  • Yura Palaha
    4 September 2019, 11:53 |

    >> но вообще не факт, что заказчик хранит в EEPROM "пароли для входа".  

    А чем плохо хранить в EEPROM пароли для входа (если результат получен надежным алгоритмом шифрования например AES и доступа к ключу для шифрования нет) ?

  • Yura Palaha
    4 September 2019, 11:49 |

    Эта идея нам не подходит.

    Нам нужно из зашифрованной строки получить исходную строку. А из исходной зашифрованую. Применив ключ (синхронный) и прогнав строки через нужную нам функцию. 

  • Profile deleted
    3 September 2019, 13:17 |

    Функция принимает на вход параметры 

    1. указатель на адрес где храниться строка “ключ”

    2. количество символов которые будут использоваться. Если число больше длины строки, то длина строки.

    3. указатель на адрес где храниться обрабатываемая строка.

    4. Флаг (зашифровать или расшифровать строку)


    Обычно подобные алгоритмы работают с блоками, размер которых кратен какому-то числу (напр., для AES это может быть 16 байтов). Соответственно, в вашем случае целесообразно обрабатывать весь блок EEPROM (512 байтов?) за раз.

    И с шифрующим кодом не всё так просто - для него требуется "ключ" (если говорим про AES), который тоже надо где-то хранить...

    Варианты:

    1. пользователь вводит ключ при шифровании "вручную" (напр., через Web-страничку, если ваше устройство её предоставляет) или скачивает с какого-то локального сервера (если устройство поддерживает такую функциональность)
    2. EEPROM загружается в устройство в зашифрованном виде

    Если ключ для шифрования хранить в данных, то защищённость такой реализации очень низкая.

    Общедоступных библиотек, реализующих AES для микроконтроллеров, достаточно - есть из чего выбрать.

  • Yura Palaha
    4 September 2019, 12:22 |

    AES алгоритм устраивает.

    Единственное не совсем понятно с блоками.

    Нам нужно чтобы  строка длиной например 10 или 20 символов была зашифрована и результат тоже был такой же длины. Или шифровать возможно только блоками. т.е. следовательно изменив один символ придется перезаписать весь блоке зашифрованным результатом ?

  • Ihor Lozovsky
    4 September 2019, 12:27 |

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

  • Yura Palaha
    4 September 2019, 12:40 |

    Ну отлично. Нам нужно побайтовый или блоками по 20 символов. В крайнем случае можно шифровать сразу по несколько строк каждая из которых до 20 символов (но может быть и увеличена в случае необходимости).


    Единственное алгоритм должен быть надежным AES устраивает.

  • Profile deleted
    4 September 2019, 15:58 |

    Единственное алгоритм должен быть надежным AES устраивает 

    В AES блоки по 16 байтов (см. https://ru.wikipedia.org/wiki/Advanced_Encryption_Standard).

    Соответственно ваши строки по 20 символов будут занимать по 32 байта в зашифрованном виде (в EEPROM).

  • Yura Palaha
    4 September 2019, 22:51 |

    Да спасибо. Я это уже понял, но теперь понимаю что понял верно. Но нет пока опыта. Нужно мне увидеть результаты работы шифрования и я тогда придумаю как извернуться чтобы память не тратить - маловато ее. 

    Пока в голову приходит самое простое.

    1. Расширить свой блок до 32 (или уменьшить до 16) - не очень мне нравиться, зато очень просто.

    2. Оставшихся 4 байта в четырех блоках шифровать отдельно - вариант динамичный поскольку блоки можно делать любого мне нужного размера,  но нужно заморачиватся с реализацией в моем скетче.

  • Profile deleted
    4 September 2019, 23:46 |

    как извернуться чтобы память не тратить - маловато ее. 

    Если имеете в виду EEPROM, то судя по официальной спецификации ATmega32U4 в этом чипе данной памяти 1024 байтов - немало, на мой взгляд.

    Для экономии памяти можно шифровать всю занятую EEPROM одним куском.

    Если этот вариант не подходит и памяти действительно окажется мало, то посмотрите в сторону других чипов, напр., esp8266 или esp32 - там данной памяти от 1 МБ, и можно даже организовать простую файловую систему (типа SPIFFS).

  • Yura Palaha
    5 September 2019, 10:04 |

    Дело в том что мне нужен аппаратный эмулятор клавиатуры.

  • Profile deleted
    5 September 2019, 11:51 |

    Эту задачу, наверное, стоит оформить отдельным проектом...

  • Sergey Mironov
    3 September 2019, 16:16 |

    Я думаю, не стоит изобретать велосипед. Все можно взломать при желании, особенно копеечный Ардуино. 100% защиту реализовать на копеечных платах невозможно априори. Таким образом, задача сводится к тому, чтобы для взломщика стоимость взлома превышала стоимость покупки. Достаточно использовать внешний ключ, к примеру, тот же RFID, который будет проверяться при каждом запуске программы. Разумеется, его можно скопировать, но для этого необходимо соответствующее оборудование, что существенно удорожает процесс.

  • Sergey Mironov
    3 September 2019, 16:18 |

    Альтернативный вариант - плата с Wifi или Ethernet, которая проверяет ключ на удаленном сервере и при его несоответствии просто не запускается.

  • Yura Palaha
    4 September 2019, 12:30 |

    Это другая история. Но чтобы получить этот ключ который храниться удаленно (через интернет) нужна защита. у нас все проще.


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

  • Profile deleted
    4 September 2019, 16:33 |

    для платы “ATmega32U4” Ардуино. 

    Поясните по поводу чипа - он у вас "пустой" или в нём уже есть какой-нибудь загрузчик (bootloader)? Т.е. как вы планируете прошивать его?

    И в каком виде вам нужна программа - только исходные коды на C/C++ или ещё файл проекта для какой-либо IDE?

  • Yura Palaha
    4 September 2019, 23:00 |

    Если я верно оцениваю ситуацию, то планирую это реализовать так.

    Есть скетч загружается посредством IDE Ардуины.

    Туда нужно добавить шифрование текста который сейчас без шифрования записывается во внешний ЕЕПРОМ.

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

Current freelance projects in the category C and C++

Script that will interact based on the image

I need a script that will interact based on the image + text (product name on the screen) + price. In other words, the script should click on the platform logo (white text in the top left) to update the range of products (every 3-5 seconds), then there should be a search by…

C and C++Python ∙ 8 proposals

Create a bot telegram with GPT integration

306 USD

The technical task: 1) Create a bot telegram for example, When you start asking the language: The Russian The English The rest is the example of the first bot: to propose to send a photo from which the face will be taken, the second - to ask for a video on which the face…

C and C++Python ∙ 12 proposals

Configurate the data exchange between Jetson nano and another device by can shi

Set the data exchange between the jetson nano and other device on the can band using the RS485 CAN documentation and examples here: https://www.waveshare.com/wiki/RS485_CAN_for_Jetson_Nano The data package that is transmitted is broken down on the frame size of 8 bytes, the…

C and C++Linux and Unix ∙ 2 proposals

Infrared temperature sensor ZigBee

Required an infrared temperature sensor with data transmission through the ZigBee protocol to the Home Assistants server in MQTT Equipment of : Module ESP32-C6-WROOM-1-N8 Infrared thermometer MLX90614 + Add LED laser to indicate where the temperature is scored

C and C++Embedded systems and microcontrollers ∙ 1 proposal

Create a bot in telegram by parsing messages

20 USD

You need to copy the functionality of this bot - t. me /lead_observer_bot The functional: 1. to put the keywords 2. to kill groups from which the parsing of messages will occur Possibility of adding and deleting words and groups Obtaining notifications of new messages by…

C and C++Python ∙ 14 proposals

Client
Yura Palaha
Ukraine Kyiv  5  0
Project published
4 years ago
306 views
Labels
  • ATmega32U4