_section: Addresses @ Explain addresses,formats and checksumming here. Also see: [constants.AddressZero](constants) _subsection: Address Formats @ _heading: Address @
An **Address** is a [[DataHexString]] of 20 bytes (40 nibbles), with optional mixed case. If the case is mixed, it is a **Checksum Address**, which uses a specific pattern of uppercase and lowercase letters within a given address to reduce the risk of errors introduced from typing an address or cut and paste issues. All functions that return an Address will return a Checksum Address. _heading: ICAP Address @ The **ICAP Address Format** was an early attempt to introduce a checksum into Ethereum addresses using the popular banking industry's [IBAN](link-wiki-iban) format with the country code specified as **XE**. Due to the way IBAN encodes address, only addresses that fit into 30 base-36 characters are actually compatible, so the format was adapted to support 31 base-36 characters which is large enough for a full Ethereum address, however the preferred method was to select a private key whose address has a ``0`` as the first byte, which allows the address to be formatted as a fully compatibly standard IBAN address with 30 base-36 characters. In general this format is no longer widely supported anymore, however any function that accepts an address can receive an ICAP address, and it will be converted internally. To convert an address into the ICAP format, see [getIcapAddress](utils-getIcapAddress). _subsection: Converting and Verifying @ _property: ethers.utils.getAddress(address) => string<[[address]]> @ @SRC
Returns //address// as a Checksum Address. If //address// is an invalid 40-nibble [[HexString]] or if it contains mixed case and the checksum is invalid, an [INVALID_ARGUMENT](errors--invalid-argument) Error is thrown. The value of //address// may be any supported address format. _code: @lang //_hide: const getAddress = ethers.utils.getAddress; // Injects the checksum (via upper-casing specific letters) //_result: getAddress("0x8ba1f109551bd432803012645ac136ddd64dba72"); //_log: // Converts and injects the checksum //_result: getAddress("XE65GB6LDNXYOFTX0NSV3FUWKOWIXAMJK36"); //_log: // Throws if a checksummed address is provided, but a // letter is the wrong case // ------------v (should be lower-case) //_throws: getAddress("0x8Ba1f109551bD432803012645Ac136ddd64DBA72") //_log: // Throws if the ICAP/IBAN checksum fails //_throws: getIcapAddress("XE65GB6LDNXYOFTX0NSV3FUWKOWIXAMJK37"); //_log: // Throws if the address is invalid, in general //_throws: getIcapAddress("I like turtles!"); //_log: _property: ethers.utils.getIcapAddress(address) => string<[IcapAddress](address-icap)> @ @SRC
Returns //address// as an [ICAP address](link-icap). Supports the same restrictions as [getAddress](utils-getAddress). _code: @lang //_hide: const getIcapAddress = ethers.utils.getIcapAddress; //_result: getIcapAddress("0x8ba1f109551bd432803012645ac136ddd64dba72"); //_log: //_result: getIcapAddress("XE65GB6LDNXYOFTX0NSV3FUWKOWIXAMJK36"); //_log: _property: ethers.utils.isAddress(address) => boolean @ @SRC
Returns true if //address// is valid (in any supported format). _code: @lang //_hide: const isAddress = ethers.utils.isAddress; //_result: isAddress("0x8ba1f109551bd432803012645ac136ddd64dba72"); //_log: //_result: isAddress("XE65GB6LDNXYOFTX0NSV3FUWKOWIXAMJK36"); //_log: //_result: isAddress("I like turtles."); //_log: _subsection: Derivation @ _property: ethers.utils.computeAddress(publicOrPrivateKey) => string<[[address]]> @ @SRC Returns the address for //publicOrPrivateKey//. A public key may be compressed or uncompressed, and a private key will be converted automatically to a public key for the derivation. _code: @lang //_hide: const computeAddress = ethers.utils.computeAddress; // Private Key //_result: computeAddress("0xb976778317b23a1385ec2d483eda6904d9319135b89f1d8eee9f6d2593e2665d"); //_log: // Public Key (compressed) //_result: computeAddress("0x0376698beebe8ee5c74d8cc50ab84ac301ee8f10af6f28d0ffd6adf4d6d3b9b762"); //_log: // Public Key (uncompressed) //_result: computeAddress("0x0476698beebe8ee5c74d8cc50ab84ac301ee8f10af6f28d0ffd6adf4d6d3b9b762d46ca56d3dad2ce13213a6f42278dabbb53259f2d92681ea6a0b98197a719be3"); //_log: _property: ethers.utils.recoverAddress(digest, signature) => string<[[address]]> @ @SRC Use [[link-wiki-ecrecover]] to determine the address that signed //digest// to which generated //signature//. _code: @lang //_hide: const recoverAddress = ethers.utils.recoverAddress; const digest = "0x7c5ea36004851c764c44143b1dcb59679b11c9a68e5f41497f6cf3d480715331"; // Using an expanded Signature //_result: recoverAddress(digest, { r: "0x528459e4aec8934dc2ee94c4f3265cf6ce00d47cf42bb106afda3642c72e25eb", s: "0x42544137118256121502784e5a6425e6183ca964421ecd577db6c66ba9bccdcf", v: 27 }); //_log: // Using a flat Signature const signature = "0x528459e4aec8934dc2ee94c4f3265cf6ce00d47cf42bb106afda3642c72e25eb42544137118256121502784e5a6425e6183ca964421ecd577db6c66ba9bccdcf1b"; //_result: recoverAddress(digest, signature); //_log: _subsection: Contracts Addresses @ _property: ethers.utils.getContractAddress(transaction) => string<[[address]]> @ @SRC
Returns the contract address that would result if //transaction// was used to deploy a contract. _code: @lang //_hide: const getContractAddress = ethers.utils.getContractAddress; const from = "0x8ba1f109551bD432803012645Ac136ddd64DBA72"; const nonce = 5; //_result: getContractAddress({ from, nonce }); //_log: _property: ethers.utils.getCreate2Address(from, salt, initCodeHash) => string<[[address]]> @ @SRC
Returns the contract address that would result from the given [CREATE2](link-eip-1014) call. _code: @lang //_hide: const getCreate2Address = ethers.utils.getCreate2Address; //_hide: const keccak256 = ethers.utils.keccak256; const from = "0x8ba1f109551bD432803012645Ac136ddd64DBA72"; const salt = "0x7c5ea36004851c764c44143b1dcb59679b11c9a68e5f41497f6cf3d480715331"; const initCode = "0x6394198df16000526103ff60206004601c335afa6040516060f3"; const initCodeHash = keccak256(initCode); //_result: getCreate2Address(from, salt, initCodeHash); //_log: