Читаем 1c2b9509b53cb0837976a7dc6c8bcd37 полностью

Безусловно, спустя десять лет с момента своего появления Биткоин выглядит

уже в какой-то степени архаичным по сравнению с более современными

блокчейн-проектами. Однако именно Биткоин заложил основы для

последующей эволюции технологии блокчейн. Мы не будем детально

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

сети Биткоин, поскольку мы их уже рассмотрели ранее. Но вместе с тем

Биткоин содержит и ряд дополнительных особенностей, которые не были

предварительно описаны. И сейчас мы остановимся на них подробнее.

Для начала попробуем разобраться, каким образом в сети Биткоин

формируется система адресации. Для того чтобы получить адрес в сети

Биткоин, необходимо в первую очередь сгенерировать пару ключей, используя

один из алгоритмов асимметричной криптографии. Биткоин, как и большинство

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

логарифмирования в группе точек эллиптической кривой (ECDSA). Как

известно, эллиптическая кривая описывается следующим уравнением: Биткоин использует форму данного уравнения в виде y2 = x3 + 7. Явное

упрощение не должно вводить читателя в заблуждение — указанных

коэффициентов вполне достаточно для того, чтобы создать значительную

вычислительную сложность в части решения обратной задачи восстановления

секретного ключа из публичного. Вообще данные для параметров

эллиптических кривых взяты из рекомендаций консорциума SECG, который

разработал «Стандарты для эффективной криптографии», использующиеся в

том числе и в проекте Биткоин. Параметры рассчитаны таким образом, чтобы

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

момент неизвестно ни об одной успешной попытке взлома алгоритма

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

квантовые компьютеры, но для этого им необходимо обзавестись достаточным

количеством кубитов, а на это потребуется время, возможно, даже весьма

значительное.

Вернемся к генерации ключей. Сначала случайным образом создается 256-

битный закрытый ключ, а затем из него математически вычисляется публичный

ключ точно такого же размера. Однако публичный ключ — это еще не совсем

адрес Биткоин. Для того чтобы он стал адресом, с ним необходимо провести

определенные процедуры. Сначала открытый ключ последовательно

пропускают через два различных алгоритма хеширования (SHA-256 и MD5). В

последнем случае его адрес укорачивается с 256 бит до 160. Затем к

полученному результату в начало добавляют один байт идентификатора сети

(основная сеть или тестовая), а в конец — четыре байта контрольной суммы

адреса, которая также представляет собой часть хеша последнего результата.

Контрольная сумма необходима для проверки, если ввод адреса

осуществляется вручную: в случае ошибочного ввода система выдаст

предупреждение. Транзакции в блокчейн являются безотзывными, поэтому

отправитель криптосредств не имеет права на ошибку. Если адрес будет

введен некорректно, средства отправителя уйдут «в никуда». А точнее — на

адрес, от которого ни у кого из потенциальных пользователей сети не будет

«отмычки» в виде секретного ключа. В результате никто не сможет предъявить

права на эти средства, которые, таким образом, будут безвозвратно потеряны

для системы.

Завершающий шаг в процедуре получения адреса Биткоин — его

преобразование в более «читаемый» вид. Для этого блок данных в формате

шестнадцатеричного кода (использующего цифры от 0 до 9 и буквы от A до F) преобразуется алгоритмом Base58 в строку, содержащую цифры, а также

маленькие и большие латинские буквы. Данная процедура необходима, чтобы

исключить из адреса символы, которые могут двояко трактоваться при ручном

наборе: например, латинская маленькая l и большая латинская I или большая

буква O и цифра 0. Все эти меры направлены на дополнительную защиту от

ошибочного ввода адреса при совершении транзакций. По завершении всех

необходимых процедур Биткоин-адрес может приобрести, например, следующий вид:

Теперь у пользователя есть свой адрес в сети Биткоин, хотя сама сеть об этом

пока еще ничего не знает, поскольку пользователь осуществлял генерацию

адреса на своем локальном устройстве. Но имея пару ключей и

сформированный из них адрес, пользователь может получать на него

криптосредства, а затем отправлять их на любой другой адрес, который

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

вопрос: куда именно попадет транзакция? Логично было бы предположить, что

она должна быть включена в блок, который в данный момент формируется

сетью. Однако это не совсем так — сначала транзакция рассылается по всей

сети через прямые соединения между различными узлами. При этом каждый

из узлов, получив новую транзакцию, осуществляет ее проверку на

«валидность». Узлы проверяют, располагает ли в действительности

отправитель той суммой, которую он желает переслать. Осуществить такую

Перейти на страницу:

Похожие книги

Linux
Linux

Книга посвящена операционной системе Linux. Приводятся подробные сведения о ее особенностях и возможностях, идеологии файловой системы, инсталляции и основных командах, вопросах компиляции ядра, настройках и сервисах. Большое внимание уделяется организации на базе Linux различных серверов и служб: электронной почты, WWW, FTP, INN, Proxy, NTP, а также проблемам администрирования сети, обеспечения безопасной работы и другим вопросам. Описаны способы настройки под Linux рабочих станций, в т. ч. и бездисковых, установки и эксплуатации на них графических сред типа X Window, а также конфигурирование модемных соединений, принтеров и сканеров, отладка взаимодействия с Linux-машинами такой «экзотической» периферии, как карманные компьютеры, мобильные телефоны, TV-тюнеры и т. п. Рассматриваемые в книге конфигурационные файлы и структура каталогов соответствуют дистрибутиву Red Hat Linux 7.x, тем не менее, при минимальной адаптации все упоминаемые в книге пакеты устанавливаются в любом дистрибутиве Linux.Для начинающих администраторов или пользователей Linux.

Алексей Александрович Стахнов

ОС и Сети, интернет
Атака на Internet
Атака на Internet

Эта книга является одним из первых специализированных изданий, написанных отечественными авторами, которое посвящено обстоятельному анализу безопасности сети Internet. В книге предлагаются и подробно описываются механизмы реализации основных видов удаленных атак как на протоколы TCP/IP и инфраструктуру Сети, так и на многие популярные сетевые операционные системы и приложения.Особое внимание авторы уделили причинам возникновения и успеха удаленных атак, а также их классификации. Были также рассмотрены основные способы и методы защиты от удаленных атак.Издание предназначено для сетевых администраторов и пользователей Internet, администраторов безопасности, разработчиков систем защит, системных сетевых программистов, студентов и аспирантов вузов, а также для всех интересующихся вопросами нарушения и обеспечения информационной безопасности компьютерных сетей.

Дмитрий Геннадьевич Леонов , Илья Давыдович Медведовский , Павел Валентинович Семьянов

ОС и Сети, интернет / Интернет / Книги по IT
Как раскрутить и разрекламировать Web-сайт в сети Интернет
Как раскрутить и разрекламировать Web-сайт в сети Интернет

Настоящая книга заинтересует всех, кто столкнулся с вопросами подготовки, размещения в Сети и популяризации Internet ресурсов различного уровня: от домашней странички до корпоративного сайта. В ней вы найдете все, что необходимо для оптимизации Web сайтов под поисковые системы: приемы написания Web-страниц, описание множества самых популярных специализированных программ, предназначенных для подготовки сайта и его раскрутки, создания удачного HTML-кода страниц с правильными метаданными.Книга является практическим руководством для разработчиков Web сайтов и всех, занимающихся их продвижением. Автор приводит множество советов, касающихся создания и анонсирования Web страниц. Рассмотрены средства автоматизации для повышения эффективности разработки и маркетинга при создании и обслуживании сайта. Описание программных и сетевых средств, автоматизирующих процессы тестирования и отладки сайта, обеспечивающих проверку работоспособности и корректности гиперссылок, синтаксиса HTML кода и грамматики размещенного на странице текста, занимает центральное место в книге. Подробно излагаются возможности таких программ, как Linkbot Developer Edition, Domain NameChecker, Retrieve, CyberSpyder Link Test, HTML Link Validator, CSE HTML Validator, A Real Validator, MetaTag ToolKit, MetaMan, WebQA.Отдельная глава посвящена регистрации Web ресурсов в поисковых системах и каталогах. Описываются программы автоматической регистрации (WebPosition, Page Promoter, Web Регистратор), способы взаимодействия с индексирующими роботами поисковых машин, правила применения метаданных. Рассматриваются приемы и методы рекламы сайтов в Internet, указаны критерии ее эффективности.Издание рассчитано на широкий круг читателей и будет полезно как начинающим создателям Web сайтов, так и профессионалам, которые хотят научиться более качественно продвигать в Сети свой Web продукт.

Александр Петрович Загуменнов

ОС и Сети, интернет