Что такое эфириум адрес

Как узнать адрес Эфириум-кошелька?

Адрес кошелька Ethereum — что это и как выглядит

Криптовалюта Эфириум считается главным конкурентом Биткоина и борется с ним за лидерство в мире виртуальных валют. На 24 августа 2018 года эта монета находится на 2-м месте по капитализации с показателем 28,2 миллиона долларов. Что касается курсовой цены, она (как и предыдущий параметр) значительно отстаёт от стоимости BTC и составляет 278 долларов. Несмотря на это, Эфириум перспективен и на фоне падения цены даже более привлекателен для инвесторов. Чтобы внести эту криптовалюту на бумажник, необходимо получить адрес хранилища — публичный идентификатор (специальный номер), о котором упоминалось выше.

Адрес кошелька Ethereum — набор символов, который создается перед проведением транзакции и предназначен для решения различных задач:

Итак, как выглядит номер кошелька Эфириум? Люди, которые не знают особенностей бумажника, нередко путают его номер с идентификатором для других криптовалют. Адрес для хранилища Ethereum начинается с нуля и состоит из определенного числа символов (от 40 до 44). В состав кода входят цифры и латинские буквы.

Как узнать номер кошелька Эфириум — главные особенности

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

Как узнать адрес Эфириум-кошелька для разных видов хранилищ — краткий обзор

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

Общий принцип получения Ethereum на кошелек имеет следующий вид:

Теперь рассмотрим, как узнать адрес кошелька Эфириум для наиболее популярных бумажников:

Ошибки в адресе кошелька Ethereum

У Биткоина также имеется первичный адрес кошелька, на который пользователи отправляют монеты намеренно, чтобы отблагодарить создателя виртуальной монеты. Считается, что первый идентификатор Bitcoin принадлежит бумажнику Сатоши Накамото. Что касается «нулевого» адреса Ethereum, на него также поступают деньги, но не в знак благодарности В. Бутерину, а по причине ошибки.

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

С такой проблемой, как правило, сталкиваются владельцы аппаратных кошельков, к примеру, Leger Nano S. Их особенность в том, что система по умолчанию задает идентификатор с одними нулями, если пользователь не указал адрес самостоятельно. Если заглянуть на форумы в Сети, можно найти множество жалоб пользователей.

Так, один владелец криптовалюты пишет, что по ошибке отправил на «нулевой» адрес 1493 монет. Если говорить в целом, за весь период существования Эфириума (с 2015 года), на идентификатор с сорока нулями после «0x» проведено больше 750 операций, а общая сумма на бумажнике составляет больше 7 тысяч монет. Сюда же попадают токены ERC20, многие из которых имеют вид бонусных. Известно, что на начальном этапе на «нулевой» адрес часто отправлялся Эфириум в количестве от 100 монет и более.

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

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

Видео о том, как создать Эфириум-кошелек:

Источник

Как создать кошелек для хранения Ethereum

Что такое кошелек Эфириум

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

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

Виды кошельков Эфириум

Хранилища криптовалют можно разделить на две основные категории: холодные и горячие.

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

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

Десктопные кошельки. Такие приложения устанавливаются на компьютер и работают с операционными системами, как Windows, Mac и Linux. Из-за того, что они имеют доступ к Интернету, они менее безопасны, чем холодные кошельки, но их преимущество в том, что они функциональны и бесплатны.

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

Мобильные кошельки. Сюда относятся хранилища в виде приложения для смартфона или планшета. Среди преимуществ, безусловно, можно выделить удобство, простоту использования и то, что их можно установить просто из Google Play или Apple Store бесплатно.

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

Аппаратные кошельки

На рынке аппаратных хранилищ для криптовалют лидируют два бренда – Trezor и Ledger, которые предлагают модели и для хранения Эфириума. Популярные варианты:

Trezor One – поддерживает более 1000 криптовалют, включая эфир, имеет монохромный дисплей с двумя кнопками, стоит около 65 долларов США;

Trezor T – поддерживает более 1000 криптовалют, включая ETH, имеет цветной сенсорный экран, стоит 170 долларов США;

Ledger Nano S – защищен PIN-кодом, на него можно установить от 3 до 20 приложений в зависимости от их размера, поддерживает несколько криптовалют, включая эфир и токены ERC-20, поставляется в шести цветовых вариантах: черном, желтом, розовом, зеленом, синем и металлическом, стоит около 70 долларов США;

Ledger Nano – поддерживает до 100 приложений одновременно, оснащен Bluetooth, что позволяет подключить его к приложению Ledger Live Mobile для доступа к монетам ETH с компьютера или смартфона, стоит около 130 долларов США;

KeepKey – выполняет те же функции, что и устройства от Ledger или Trezor: хранит ключи в автономном режиме, позволяет делать резервные копии и генерировать ключи из 12 символов для восстановления доступа к крипте на другом устройстве, стоит около 140 долларов США.

Мобильные кошельки

На рынке представлено не так много мобильных хранилищ для эфира, разработанных или одобренных командой Ethereum. Проверенный и наиболее востребованный мобильный кошелек – Jaxx, который работает на всех устройствах и дает владельцу полную свободу и гибкость в обращении Эфириума. Приложение имеет интуитивно понятный интерфейс и широкий набор функций. Его особенность – новая система шифрования данных с помощью алгоритма AES-256, усиленного 5000 циклами хеширования пароля по стандарту PBKDF2.

Читайте также:  что собрать мужу на вахту

Десктопные кошельки

Актуальные криптобумажники для хранения эфира с установкой на компьютер:

Guarda – поддерживает более 40 блокчейнов и тысячи их токенов, функцию обмена монет и возможность покупки любой криптовалюты с помощью банковской карты;

Exodus – поддерживает около 100 криптовалют, включая Эфириум, не хранит никаких личных данных, принадлежащих клиентам, и требует обязательного подключения к интернету для доступа к активам;

Atomic Wallet – поддерживает более 300 криптовалют, позволяет управлять ETH и другими токенами ERC20, покупать и обменивать эфир на другие криптовалюты внутри кошелька.

Браузерные кошельки

Среди популярных и проверенных браузерных криптобумажников для хранения Ethereum:

MetaMask – предназначен как для Ethereum, так и для других токенов на его основе, имеет простой и понятный интерфейс, сохраняет ключи на компьютере пользователя, доступен для браузеров Chrome, Opera, Mozilla и других;

MyEtherWallet – подходит для Эфириума и всех токенов на основе ERC20, предлагает пользователю клиентский интерфейс с возможностью подключения холодного кошелька.

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

Как создать кошелек Ethereum

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

Для регистрации криптобумажнику вам нужно выполнить несколько простых действий:

Посетите официальный сайт MyEtherWallet – www.myetherwallet.com, введите надежный пароль длиной не менее 9 символов и сгенерируйте кошелек, нажав «By Keystore File»».

Откройте криптокошелек. Для этого нужно использовать файл хранилища ключей, выбрав соответствующий пункт в меню, после чего нажать «Enter».

Получить номер кошелька. После разблокировки хранилища вы сможете выбрать монеты ETH или другие токены ERC-20 для использования, а также скопировать номер кошелька для отправки и получения крипты.

Теперь вы можете отправлять и получать монеты Ethereum и другие токены со своего личного криптокошелька. Просто нажмите «Отправить эфир и токены», выберите тип закрытого ключа, который хотите использовать (хранилище ключей / файл JSON), и выберите файл кошелька.

Как отправлять монеты ETH и токены ERC-20 с кошелька

Для отправки крипты нужно указать адрес кошелька, на который будет переслан эфир, и сумму, после этого нажать «Сгенерировать транзакцию», а затем «Отправить». Управлять токенами ERC20 в кошельке MyEtherWallet так же просто, как и ETH. После входа в кошелек нажмите оранжевую кнопку «Показать все токены», чтобы увидеть весь список поддерживаемых токенов в их сокращенной форме. Теперь щелкните на любой токен, чтобы загрузить его, и включите в MyEtherWallet. Если токен еще не поддерживается MEW, его можно добавить его самостоятельно, введя необходимую информацию.

Как пополнить кошелек Ethereum

Передавать монеты на кошелек MyEtherWallet можно несколькими способами:

через платежные сервисы;

через обменники криптовалют;

через другие официальные кошельки Ethereum.

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

Источник

Как создать эфириум кошелек?

Криптовалюта ethereum (ETH, эфир) является второй по рыночной капитализации и объему совершаемых транзакций после биткоина. За 2017 г. ее курс поднялся в 20 раз, а в течение 2018 года значительно потерял в связи с общим падением крипторынка. Но это обстоятельство ни в коей степени не отражается на высоком потенциале этой монеты: она по-прежнему востребована и сохраняется на тысячах eth-кошельков по всему миру.

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

Виды ethereum-кошельков

Рассмотрим несколько популярных способов как создать эфириум кошелек:

Регистрация эфириум-кошелька на online-сервисе

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

Как создать холодный эфириум-кошелек?

К преимуществам аппаратного хранения, помимо высокой степени безопасности, относят удобный интерфейс, локальную сохранность ключей, мультиплатформенность. Главные минусы — необходимость скачивать громадный по объему blockchain Ethereum и продолжительное ожидание синхронизации. Для создания холодного кошелька воспользуйтесь официальным клиентом Mist на сайте Github.com. Ваши действия:

Регистрация эфириум-кошелька на бирже

Регистрация эфириум-кошелька на торговой площадке EXMO

Завести eth-бумажник на «Эксмо» может любой пользователь, прошедший процедуру регистрации. Для этого нужно набрать электронный адрес, пароль, логин, поставить галочку о согласии с правилами сервиса и ввести капчу.

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

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

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

Кошелек Jaxx

Установить эфириум-кошелек на декстопный компьютер можно на офсайте создавшей его компании (пользоваться для этого сторонними ресурсами не рекомендуется). То же самое можно сделать со смартфона или планшета через приложения AppStore и GooglePlay.

Кошелек Exodus

Онлайн-кошелек Exodus был выпущен летом 2016 г. и буквально за несколько недель обрел огромную популярность. И тому есть несколько причин: простой интерфейс, поддержка 16 криптоактивов, включая ВТС и ETH, интеграция с биржей ShapeShit, поддержка всех популярных ОС, приятный дизайн сайта.

Чтобы установить «Эксодус», необходимо:

Регистрация бумажника также предельно простая, напоминающая стандартную

процедуру создания учетной записи в соцсетях.

Кошелек Coinbase

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

Для создания Коинбейс-кошелька нужно:

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

Лучшие кошельки для Эфириума

Как пополнить ethereum-wallet?

Через обменный пункт

Последовательность проведения операции:

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

Биржа «Эксмо» (exmo.me), о которой мы уже писали выше, обеспечивает достаточно высокий уровень безопасности вкладов по сравнению с аналогичными площадками и предоставляет доступ к сотнями направлений обмена. Еще одно ее преимущество: наличие удобного инструмента для онлайн-мониторинга курса криптоактивов.

Для отправки монет с кошелька на счет другого пользователя электронной платежной системы нужно:

Подтверждение отправки криптовалютных средств

В среднем операции с монетами eth осуществляются в течение 5-10 мин. в зависимости от ресурса. Отслеживать свои транзакции можно на отдельной странице кошелька.

Итоги

Какой бы способ хранения эфиров вы ни выбрали, возможности для совершения платежей будут примерно равны. Завести кошелек несложно, единственное условие: наличие свободного пространства на диске в случае необходимости скачивания блокчейна ETH.

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

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

Источник

Учебник по Solidity. Все об адресах

Продолжаем серию статей про язык Solidity и платформу Ethereum. В этой статье будет рассказываться про адреса в Ethereum. Статья была написана в августе 2019 года, с той порой язык изменился, поэтому несоответствия в описании автора были исправлены.

Во введении проведено сравнение Ethereum адресов с почтовыми адресами в реальном мире.

Техническая часть начинается с раздела «Что такое (технически) адрес в Ethereum?»

Оглавление

Что такое (технически) адрес Ethereum?

Основы адресов в Solidity

address vs address payable

Методы доступные при работе с адресами

Преобразование типов address и address payable

Методы возвращающие тип address

1. Введение

На август 2021 года в блокчейне Ethereum насчитывается почти 166 миллионов уникальных адресов!

Давайте начнем с очень простого примера, чтобы понять, что такое адреса в Ethereum (и в блокчейне в целом). Для этого нам нужно представить себе сценарий.

Читайте также:  для получения выплаты на ребенка к школе необходимо 2021 году

Вы находитесь в отпуске в Суздали. Вы впервые посещаете этот город, и он вам очень понравился! Настолько, что вы решили сказать своему другу Алексу Цветкову, что он обязательно должен его посетить.

Хорошим способом намекнуть ему об этом будет отправка открытки с изображением Суздальского Кремля.

Вы идете на почту, и почтальон спрашивает вас: «Куда отправить?», на что вы отвечаете: «Моему другу, Алексу Цветкову».

Сотрудник за стойкой обязательно скажет, что:

он не знает, КТО этот ваш друг и

он не знает, ГДЕ он живет.

Поскольку вы знаете адрес Алекса, вы напишете его на открытке и передадите ее сотруднику почтового отделения.

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

Когда письмо прибудет в Москву, почтальон возьмет его и опустит в почтовый ящик Алекса Цветкова: это его домашний адрес.

Простые аналогии

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

Адрес в Ethereum имеет схожие характеристики с почтовыми адресами. Благодаря использованию криптографии с открытым ключом.

Уникальность адреса

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

Даже если в мире существует несколько Алексов Цветковых, но есть только один Алекс Цветков, проживающий по адресу «RU, 121552, Москва, ул. Ярцевская, д. 30«.

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

Личное и секретное

Ключ вашего почтового ящика не только уникален, но также личный и секретный. С уникальностью мы уже познакомились, теперь давайте рассмотрим «личный» и «секретный».

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

Аналогично в Ethereum, ваш закрытый ключ хранится в вашем кошельке. Только вы должны знать его и никогда не делиться им!

Управление секретным (закрытым) ключом

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

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

Заметка: закрытый или секретный ключ? По сути это одно и тоже. Если вы говорите про “открытый ключ”, то в пару к нему говорите “закрытый ключ”. Если говорите “публичный ключ”, то говорите “секретный ключ”. Зависит от ваших предпочтений как использовать русский язык. Далее по тексту будет использоваться “закрытый” ключ.

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

Закрытые ключи в Ethereum позволяют отправлять ether путем подписания транзакций. Единственным исключением являются смарт-контракты, как мы увидим позже.

Различные типы адресов

Виды адресов в Ethereum: Externally owned accounts, contract accounts

External owned accounts (учетные записи, принадлежащие внешним пользователям, EOA): контролируются закрытыми ключами.

Закрытый ключ даёт контроль над ether на счёте и над процессами аутентификации, необходимой счёту при взаимодействии со смарт-контрактами. Они (закрытые ключи) используются для создания цифровых подписей, которые требуются для транзакций по расходованию любых средств на счете.

Contract accounts (учетные записи смарт-контрактов, CA): самоуправляемы своим своим кодом.

В отличие от EOA, у смарт-контрактов нет открытых или закрытых ключей. Смарт-контракты поддерживаются не закрытым ключом, а присущим им кодом. Можно сказать, что они «владеют собой».

Адрес каждого смарт-контракта определяется в ходе выполнения транзакции по созданию смарт-контракта, как результат функции от источника транзакции и nonce. Ethereum адрес смарт-контракта можно использовать в транзакции в качестве получателя, отправляя средства на смарт-контракт или вызывая одну из функций смарт-контракта.

2. Что такое (технически) адрес Ethereum?

Хэш-функции являются ключевым элементом при создании адресов. Ethereum использует хэш-функцию keccak-256 для генерации адресов.

В Ethereum и Solidity адрес имеет размер в 20 байт (160 бит или 40 шестнадцатеричных символов). Он соответствует последним 20 байтам хэша (keccak-256) открытого ключа. Адрес всегда имеет префикс 0x, поскольку он представлен в шестнадцатеричном формате (нотация base16).

Как создается адрес Ethereum?

Очень полезно понять процесс создания адреса в Ethereum. Это позволит по-другому взглянуть и понять, как устроена платформа Ethereum.

Мы будем ссылаться на официальную техническую спецификацию блокчейна Ethereum: желтую бумагу. Хотя она выглядит сложной и трудночитаемой, я помогу вам понять ее, разбив описание на небольшие шаги, которые легко усвоить.

Процесс создания адресов в Ethereum можно разделить на два типа: создание EOA адресов и создание адресов смарт-контрактов.

Как создаются EOA адреса?

Давайте используем спецификацию Yellow Paper и создадим адрес Ethereum с нуля. Мы будем использовать эту статью Винсента Кобеля в качестве пошагового руководства по созданию адреса Ethereum.

1. Начнём с открытого ключа (128 символов / 64 байта)

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

2. Применим хэш (keccak-256) к открытому ключу. Должна получиться строка длиной 64 символа / 32 байта.

3. Возьмем последние 40 символов / 20 байт из полученного хэша или отбросьте первые 24 символа / 12 байт.

Эти 40 символов / 20 байт являются адресом.

С префиксом 0x адрес фактически становится длиной 42 символа. Кроме того, важно отметить, что они нечувствительны к регистру. Все кошельки должны понимать адреса Ethereum, выраженные заглавными или строчными символами. (Начиная с EIP-55, адреса в верхнем регистре используются для проверки контрольной суммы)

0x001d3f1ef827552ae1114027bd3ecf1f086ba0f9 или 0X001D3F1EF827552AE1114027BD3ECF1F086BA0F9

Как создаются адреса смарт-контрактов?

Адреса смарт-контрактов создаются по-другому. Они детерминировано вычисляются из двух вещей:

Адрес создателя смарт-контракта: sender

Сколько транзакций отправил создатель: nonce

Ниже описаны шаги по созданию адреса смарт-контракта

Возьмите значения sender и nonce.

Закодируйте их с помощью RLP

Захэшируйте результат с помощью Keccak-256

Адреса в кратком изложении

В целом, основными характеристиками адресного типа в Solidity являются:

Длина 20 байт (160 бит): как уже было сказано, Ethereum адрес соответствует последним 20 байтам хэша Keccak-256 связанного с ним открытого ключа.

Шестнадцатеричный формат (нотация base16): Ethereum адрес содержит ровно 40 символов (2 символа = 1 байт) из шестнадцатеричного диапазона (0 1 2 3 4 5 6 7 8 9 или a b c d e f).

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

3. Основы адресов в Solidity

Как определить переменную адресного типа?

Чтобы определить переменную адресного типа, укажите ключевое слово address перед именем переменной.

address user = msg.sender;

Мы использовали встроенную функцию Solidity msg.sender для получения адреса текущего аккаунта, взаимодействующего со смарт-контрактом.

Но вы можете жёстко закодировать определенные адреса в коде Solidity, используя адресные литералы. Они описаны в следующем разделе.

Адресные литералы

Вот пример того, как объявить литерал адреса в Solidity.

address owner = 0xc0ffee254729296a45a3885639AC7E10F9d54979;

Как уже отмечалось ранее, литерал адреса должен:

содержать 40 символов (длиной 20 байт), и

должны иметь префикс 0x.

имеют правильную контрольную сумму

Что касается пункта 3), адресные литералы должны иметь правильную контрольную сумму. Если они не проходят тест на контрольную сумму, Remix или компилятор Solidity выдадут предупреждение и будут рассматривать их как обычные интервалы чисел. Формат контрольной суммы адреса в смешанном регистре определен в EIP-55.

4. address vs address payable?

В Solidity, с точки зрения отправителя:

Вы можете отправить ether в переменную, определенную как address payable

Вы не можете отправить ether в переменную, определенную как address

Вы можете использовать ключевое слово payable перед именем переменной типа address, чтобы позволить переменной принимать ether.

Примечание: Тип, возвращаемый msg.sender, является типом address payable.

5. Методы, доступные при работе с адресами

Примечание: количество ether в _amount, указанное в качестве параметра в приведенных ниже методах, выражается в Wei (18 нулей):

Читайте также:  что съесть перед тренировкой на сушке

1 ether = 1¹⁸ wei = 1 000 000 000 000 000 000 000 000 000 000 wei

Все методы типа address в Solidity:

Мы разделим методы, связанные с адресами, на 3 категории и 2 типа транзакций:

Методы, связанные с ether

возвращает баланс счета в wei.

Любая переменная, определенная как address, имеет метод balance(). Этот метод позволяет получить количество ether, хранящегося на счете, принадлежащем внешнему владельцу (EOA / пользователю) или смарт-контракту. Возвращаемое число представляет собой количество ether в wei.

В приведенном ниже коде показано, как получить ether баланс вашего адреса. В примере мы используем msg.sender.

На самом деле существует два способа посмотреть баланс Ethereum адреса.

Если вы хотите получить остаток по текущему смарт-контракту, мы можем использовать address(this) (это явное преобразование).

Переводит указанное количество ether (в wei) на указанный address.

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

Потребляет 2 300 gas.

Под капотом функция transfer() запрашивает баланс адреса, применяя свойство balance, перед отправкой ether.

Метод: address.send(uint256) returns (bool)

Использование send сопряжено с некоторыми опасностями: передача не состоится, если глубина стека вызовов равна 1024 (это всегда может быть принудительно исправлено вызывающей стороной), а также если у получателя закончится gas. Поэтому для безопасных переводов ether всегда проверяйте возвращаемое значение send, используйте transfer или даже лучше: используйте шаблон, в котором получатель снимает деньги.

Возвращает false при неудаче (Внимание: всегда проверяйте возвращаемое значение send).

Потребляет газ в размере 2300.

Методы взаимодействия со смарт-контрактами

Solidity предлагает удобный способ вызова функций удалённых смарт-контрактов (например: targetContract.doSomething(. ) ). Однако этот высокоуровневый синтаксис доступен только в том случае, если интерфейс удалённого смарт-контракта известен на этапе компиляции.

В EVM представлено 4 специальных операционных кодов (opcode) для взаимодействия с другими смарт-контрактами, из которых 3 доступны, как методы типа address: call, delegatecode и staticcall.

Примечание: callcode устарел, но все еще доступен в низкоуровневых ассемблерных вставках.

Все низкоуровневые функции, определенные ниже, принимают один аргумент: необработанное сообщение (Может быть создано в библиотеке web3 с помощью encodeABI()).

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

Мы рассматриваем сценарий, в котором смарт-контракт A взаимодействует с смарт-контрактом B

Кто вызывает функции удалённого смарт-контракта (отправляет сообщения)? Хранилище какого смарт-контракта обновляется?

Технические детали (возвращаемые значения, передаваемый gas и т.д.)

Метод: address.call(bytes memory) returns (bool, bytes memory)

Типичный случай: смарт-контракт A хочет выполнить функцию смарт-контракта B, которая обращается или изменяет хранилище смарт-контракта B. Вызов B.function() может обновить только хранилище B.

ПРЕДУПРЕЖДЕНИЕ: НЕБЕЗОПАСНО! Получатель может (случайно или злонамеренно) израсходовать весь ваш газ, в результате чего ваш смарт-контракт остановится с исключением out of gas (OOG); всегда проверяйте возвращаемое значение метода call.

Спецификация

Отправляет сообщение (низкоуровневый CALL, см. опкод OxF1), передавая полезную нагрузку полученную в аргументе и помеченную как memory.

Передаёт весь доступный газ.

Возвращает кортеж с:

истинностное значение результата вызова (true при успехе, false при неудаче или ошибке).

данные в байтовом формате.

Типичный случай: смарт-контракт A по сути копирует себе функцию B. Выполнение функции смарт-контракта В будет происходить в контексте смарт-контракта A, возможно взаимодействие со хранилищем смарт-контракта А. Вызов B.function() обновит хранилище A.

Спецификация

Низкоуровневая функция CALLCODE, подобная address(this).call(. ), но с заменой кода этого смарт-контракта на код адреса.

Возвращает false при ошибке.

Метод: address.delegatecall(bytes memory) returns (bool, bytes memory)

Типичный случай: смарт-контракт A хочет выполнить функцию смарт-контракта B, при этом функция будет выполнена в контексте смарт-контракта А. При этом функция B может перезаписать хранилище A и выдать себя за A для любого другого смарт-контракта. Тогда msg.sender будет адресом A, а не B.

В этом случае смарт-контракт A по сути делегирует вызов функции смарт-контракту B. Разница с прежним методом callcode заключается в том, что использование delegatecall позволяет не только перезаписать хранилище смарт-контракта A. Но и если смарт-контракт B вызовет другой смарт-контракт C, смарт-контракт C увидит, что отправителем msg.sender является смарт-контракт A.

Спецификация

Низкоуровневая операция DELEGATECALL (см. опкод OxF4) (с полным контекстом msg, видимым текущим смарт-контрактом), передавая полезную нагрузку полученную в аргументе и помеченную как memory.

Передаёт весь доступный газ

Возвращает кортеж с:

истинностным значением как результатом вызова (true при успехе, false при неудаче или ошибке).

данные в байтовом формате.

Метод: address.staticcall(bytes memory) returns (bool, bytes memory)

Спецификация

Низкоуровневая операция STATICCALL (см. опкод OxF4) (с полным контекстом msg, видимым текущим смарт-контрактом), передавая полезную нагрузку полученную в аргументе и помеченную как memor.

Возвращает кортеж с:

истинностным значением как результат вызова (true при успехе, false при неудаче или ошибке).

данные в байтовом формате.

Передаёт весь имеющийся газ

Дополнительные параметры для вызовов низкого уровня

При взаимодействии с смарт-контрактами в Solidity через низкоуровневые вызовы call(. ), delegatecall(. ) и staticcall(. ) у вас есть возможность добавить некоторые пользовательские параметры (немного похоже на web3js). Это позволит вам указать, например, сколько ether вы хотите отправить по адресу, указанному в вызове (value), а также сколько gas вы готовы использовать.

В приведенном ниже фрагменте кода приведен пример.

6. Преобразование типов address и address payable

Допускаются неявные преобразования из address payable в address

Неявные преобразования из address в address payable невозможен (за исключением address payable к address payable).

Явное преобразование из и в address разрешено для: целых чисел uint160, целочисленных литералов, bytes20 и типа contract.

Только выражения типа address и contract могут быть преобразованы в тип address payable с помощью явного преобразования payable(. ). Для типа contract это преобразование допустимо только в том случае, если смарт-контракт может получать ether, т.е. смарт-контракт либо имеет функцию receive, либо функцию fallback c payable. Обратите внимание, что payable(0) допустимо и является исключением из этого правила.

Контракты как address

Начиная с версии 0.5.0 Solidity, смарт-контракты больше не cодержат тип address, но все еще могут быть явно преобразованы в address или address payable (если у них есть функция receive или fallback payable).

Примечание: преобразование выполняется с использованием address(переменная) и payable(address(переменная)).

Операторы используемые с address

С address доступны следующие операторы: = и >.

7. Методы, возвращающие тип address

msg.sender

msg.sender() возвращает address payable.

Как следует из названия, функция msg.sender возвращает адрес, который инициировал вызов этого смарт-контракта. Однако важно отметить следующее:

msg.sender возвращается в текущем вызове. Он не обязательно возвращает отправителя EOA, который отправил транзакцию.

Если смарт-контракт A вызван непосредственно в транзакции отправленной с EOA, то в msg.sender будет адрес EOA.

Если смарт-контракт A вызван другим смарт-контрактом B, где B был вызван транзакцией отправленной с EOA, то в msg.sender будет адрес смарт-контракта B.

tx.origin

Предупреждение: небезопасно!

tx.origin() возвращает address.

tx.origin возвращает EOA адрес отправителя изначальной транзакции. Таким образом, возвращается полная цепочка вызовов.

block.coinbase

block.coinbase() возвращает address payable.

Адрес добытчика текущего блока, т.е. адрес получателя платы за текущий блок и вознаграждения за блок.

ecrecover(bytes32 hash, uint8 v, bytes32 r, bytes32 s) returns (address)

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

r = первые 32 байта подписи

s = вторые 32 байта подписи

v = последний 1 байт подписи

ecrecover возвращает address, а не address payable.

8. Нулевой адрес

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

Так какой же адрес следует указывать в качестве получателя, когда речь идет о создании смарт-контракта?

Создание смарт-контракта в Ethereum предполагает создание специальной транзакции, адресом назначения которой является адрес: 0x00000000000000000000000000000000000000000000000000, также известный как нулевой адрес.

Раздел, связанный с нулевыми адресами из YellowPaper.

Виртуальная машина Ethereum (EVM) понимает, что транзакция направлена на создание нового смарт-контракта, если в поле получателя указан этот нулевой адрес. Этот адрес также имеет длину 20 байт, но содержит только пустые байты 0x0.

В сети Ethereum майнеры выполняют такую транзакцию (содержащую нулевой адрес), как инструкцию по созданию нового смарт-контракта.

Источник

Академический образовательный портал