🇧🇷
Ethereum Developer Pack - PT
  • Ethereum Developer Pack - PT
  • Módulo 1
    • Introdução a Smart Contracts
      • Fundamentos de Blockchain
        • Histórico
        • Bitcoin
        • O que é Blockchain
        • Conceitos-chave em Blockchain
        • Como funciona a Blockchain
        • Tipos de Blockchain
        • Modelos de Consenso
      • A nova Internet
        • Web 3
        • Elementos Fundamentais
        • Impacto do Ethereum em Diversos Setores
      • Wallets
        • Componentes de uma wallet
        • Tipos de Wallet
        • Códigos Mnemônicos
      • Ethereum 101
        • Smart Contracts
        • Contas
          • Tipos de contas
          • Conteúdo das contas
        • Transações
          • Componentes
          • Ciclo de vida
        • Gás
        • Solidity
        • EVM
          • A máquina de estados
          • Opcodes
          • Como funciona a EVM
          • Clientes de execução
          • DApps
      • Blockchain Explorer
        • Funções de um blockchain explorer
        • Beneficios de utilizar um blockchain explorer
      • Remix
        • Características do Remix
        • Workspaces ou espaços de trabalho
        • Carregar e compilar um contrato
        • Implantar na máquina virtual do Remix (Remix VM)
        • Interagindo com funções
        • Deployar em uma rede pública
      • Crie seu primeiro Smart Contract
  • Módulo 2
    • Fundamentos de Solidity
      • Hello World
      • Tipos de Dados
      • Funções
      • Variáveis
        • Exercício 1
      • Operadores
        • Ejercicio 2
      • Constructor
        • Exercício 3
      • Convenções de nomenclatura
      • Tipos de armazenamento para variáveis
      • Estruturas de Controle
        • Exercício 4
      • Modificadores
      • Eventos
        • Exercício 5
      • Tipos de Referencia
        • Arrays
          • Exercício 6
        • Mappings
          • Exercício 7
        • Structs
          • Exercício 8
      • Address Payable
      • Como os contratos e funções recebem Ether.
      • Transferências de Ether
      • Conceitos Avançados
        • Codificação de ABI
        • Hashing
        • This
        • Herança
        • Abstract
        • Interface
        • Chamada entre contratos
        • EVM
        • ABI
        • Bytecode
        • Opcodes
  • Módulo 3
    • ERCs, Bibliotecas e Padrões de Desenvolvimento
      • Boas Práticas de Desenvolvimento
      • Padrões de Desenvolvimento
      • EIP & ERC
      • ERC-20
      • ERC-721
      • Open Zeppelin
      • Crie um Token ERC-20
      • Almacenamiento Descentralizado: IPFS
      • Crea un Token ERC-721
      • DeFi
  • Módulo 4
    • Kit de ferramentas para desenvolvimento na Ethereum
      • Requisitos para o módulo 4
        • Terminal
        • Git e Github
        • Node.js e npm
        • Visual Studio Code para Solidity
      • Toolkit
        • JSON-RPC
        • Ethers.js
          • Exercício
        • Hardhat
          • Implantação de um contrato no Hardhat
          • Implantação de um contrato em uma rede pública
        • Scaffold-ETH
          • Características do Scaffold-ETHCaracterísticas
          • Como instalar o Scaffold-ETH
  • Módulo 5
    • Segurança, Testes e Auditorias
      • Testes
        • Importância de realizar testes
        • Métodos para testar contratos inteligentes
          • Testes automatizados
          • Testes manuais
        • Conceitos importantes em testes
        • Ferramentas para testes
        • Testes com Hardhat
        • Recursos adicionais
      • Segurança
        • Uma mentalidade diferente de design
        • Principais vulnerabilidades em contratos inteligentes
          • Reentrancy attack (ataque de reentrada)
          • Replay attack (ataque de repetición)
          • Price Oracle Manipulation (Manipulación de Oráculos de Precios)
          • Missing Access Control (Pérdida de Control de Acceso)
          • Reward Manipulation (Manipulación de Recompensas)
          • Failure to Initialize (Falla al Inicializar)
          • Front-running
          • Invariant Breaks (Quebra de Invariantes)
          • Mishandling of ETH (Má gestão de ETH)
          • Denial of Service (DoS - Negação de Serviço)
          • Integer overflow and underflow (Overflow e Underflow de inteiros)
          • Phishing y Typosquatting
        • Recursos adicionais
      • Auditoria de smart contracts
        • Processo de Auditoria
        • Ferramentas
        • Como se preparar para uma auditoria
        • O teste Rekt
        • Desafios
        • Recursos adicionais
  • Contribuye
    • Kipu Explorer
Powered by GitBook
On this page
  1. Módulo 1
  2. Introdução a Smart Contracts
  3. Fundamentos de Blockchain

Histórico

PreviousFundamentos de BlockchainNextBitcoin

Last updated 6 months ago

Blockchain é uma tecnologia que tem evoluído e sido utilizada em uma grande variedade de aplicacões muito além de criptomoedas. Embora o , publicado em 2008 por uma pessoa ou grupo de pessoas, usando o pseudônimo de Satoshi Nakamoto, seja considerada a origem das blockchains, na verdade, o Bitcoin é o resultado da combinacão de várias tecnologias desenvolvidas anteriormente, como a criptografia de chave publica e a teoria dos jogos, por exemplo.

Antes do surgimento da blockchain, houveram tentativas de criar moedas digitais, mas sem sucesso.

A seguir, algumas das tecnologias que possibilitaram o surgimento do conceito de blockchain:

  • 1979 - Merkle Tree : Ralph Merkle propõe uma estrutura de dados criptográficos chamada "Merkle Tree" ou "Árvore de Merkle", que permite a verificacão eficiente de grandes quantidades de dados. A Merkle Tree divide os dados em blocos e os organiza em uma estrutura de árvore, onde cada bloco está vinculado ao seu bloco pai através de uma função de hash criptográfico.

  • 1989 - DigiCash : O sistema DigiCash utilizava uma moeda digital chamada "eCash" que podia ser comprada em um banco e ser usado para pagamentos online. , é considerado uma das primeiras empresa a desenvolver uma criptomoeda e sendo uma base para o desenvolvimento da tecnologia blockchain e das criptomoedas como o Bitcoin.

  • 1992 - Controle de modificações de documentos digitais: Haber e Stornetta propuseram o controle temporal de documentos em Merkle Trees. Publicaram propondo um sistema para assegurar que os blocos não pudessem ser modificados e interligados criptograficamente.

  • 1997 - Hashcash : que utiliza uma função de hash ciptográfico para criar um token que prova que foi realizado esforço computacional. Utilizado principalmente para combater spam de correios eletrônicos.

  • 1998 - B-Money e Bit Gold : Foram duas propostas de criptomoedas prévias ao Bitcoin, focadas em privacidade e justa distribuição (), e na criptografia e como moeda de lastro(Ouro Digital) para outras criptomoedas (). Wei Dai, criador do B-Money propôs que cada node participante na rede guarde uma cópia completa do registro de transações realizadas. Por outro lado, foi o famoso Nick Zsabo quem esteve por traz da criacão do Bit Gold.

  • 1999 - P2P : Shawn Fanning criou uma aplicacão chamada "Napster" que permitia os usuários compartilhar músicas entre si de forma decentralizada, sem necessidade de uma servidor centralizado. Isto foi possível graças a tecnologia P2P ou "peer-to-peer", que permitia os usuários se conectarem diretamente e compartilhar arquivos.

  • 2004 - RPoW : Hal Finney cria Reusable Proof of Work , uma criptomoeda baseada em prova de trabalho que utiliza tokens que podem ser reutilizados, ao invés de gerar novos tokens.

  • 2008 - Bitcoin : Uma pessoa ou grupo de pessoas que entitula Satoshi Nakamoto, publicou um documento chamado "Bitcoin: A Peer-to-Peer Eletronic Cash System", que descrevia uma nova criptomoeda baseada na tecnologia blockchain.

whitepaper do Bitcoin
Embora o DigiCash não tenha alcançado sucesso comercial
papers
Uma tecnologia de Proof of Work
B-Money
Bit Gold
(RPoW)