Warum mein Token-Inhaber bei Etherscan bei 0 bleibt

Ich habe einen Smart Contract im Ropsten-Testnetz bereitgestellt, um ein ERC-20-Token zu erstellen, aber obwohl es zeigt, dass ich den gesamten Vorrat des Tokens besitze, bleibt mein Token-Besitz auf Etherscan bei 0 %, wenn ich mein Token auf Metamask hinzufüge. (Ich verwende die Beta-Version von Metamask)Geben Sie hier die Bildbeschreibung ein

Geben Sie hier die Bildbeschreibung ein

Hier ist der Code meines SC:

pragma solidity 0.4.21;

contract ERC20Basic {
  uint256 public totalSupply;
  function balanceOf(address who) public view returns (uint256);
  function transfer(address to, uint256 value) public returns (bool);
  event Transfer(address indexed from, address indexed to, uint256 value);
}

contract ERC20 is ERC20Basic {
  function allowance(address owner, address spender) public view returns (uint256);
  function transferFrom(address from, address to, uint256 value) public returns (bool);
  function approve(address spender, uint256 value) public returns (bool);
  event Approval(address indexed owner, address indexed spender, uint256 value);
}

library SafeMath {
      function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    if (a == 0) {
      return 0;
    }
    uint256 c = a * b;
    assert(c / a == b);
    return c;
  }

  function div(uint256 a, uint256 b) internal pure returns (uint256) {
// assert(b > 0); // Solidity automatically throws when dividing by 0
    uint256 c = a / b;
// assert(a == b * c + a % b); 
    return c;
  }

  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
assert(b <= a);
return a - b;
  }

  function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
assert(c >= a);
return c;
  }
}


contract BasicToken is ERC20Basic {
  using SafeMath for uint256;

  mapping(address => uint256) balances;

  function transfer(address _to, uint256 _value) public returns (bool) {
require(_to != address(0));
require(_value <= balances[msg.sender]);

// SafeMath.sub will throw if there is not enough balance.
balances[msg.sender] = balances[msg.sender].sub(_value);
balances[_to] = balances[_to].add(_value);
emit Transfer(msg.sender, _to, _value);
return true;
  }

  function balanceOf(address _owner) public view returns (uint256 balance) {
return balances[_owner];
  }

}

contract StandardToken is ERC20, BasicToken {

  mapping (address => mapping (address => uint256)) internal allowed;

  function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
require(_to != address(0));
require(_value <= balances[_from]);
require(_value <= allowed[_from][msg.sender]);

balances[_from] = balances[_from].sub(_value);
balances[_to] = balances[_to].add(_value);
allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
emit Transfer(_from, _to, _value);
return true;
  }

  function approve(address _spender, uint256 _value) public returns (bool) {
allowed[msg.sender][_spender] = _value;
emit Approval(msg.sender, _spender, _value);
return true;
  }

  function allowance(address _owner, address _spender) public view returns (uint256) {
return allowed[_owner][_spender];
  }

  function increaseApproval(address _spender, uint _addedValue) public returns (bool) {
allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(_addedValue);
emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
return true;
  }

        function decreaseApproval(address _spender, uint _subtractedValue) public returns (bool) {
uint oldValue = allowed[msg.sender][_spender];
if (_subtractedValue > oldValue) {
  allowed[msg.sender][_spender] = 0;
} else {
  allowed[msg.sender][_spender] = oldValue.sub(_subtractedValue);
}
emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
return true;
  }

    }

contract Ownable {
   address public owner;


   event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);


  function Ownable() public {
owner = msg.sender;
  }

   modifier onlyOwner() {
require(msg.sender == owner);
_;
  }


  function transferOwnership(address newOwner) public onlyOwner {
require(newOwner != address(0));
emit OwnershipTransferred(owner, newOwner);
owner = newOwner;
  }

}

contract Pausable is Ownable {
   event Pause();
   event Unpause();

  bool public paused = false;

  modifier whenNotPaused() {
require(!paused);
_;
  }

  modifier whenPaused() {
require(paused);
_;
  }

  function pause() onlyOwner whenNotPaused public {
paused = true;
emit Pause();
  }

   function unpause() onlyOwner whenPaused public {
paused = false;
emit Unpause();
  }
 }

contract PausableToken is StandardToken, Pausable {

  function transfer(address _to, uint256 _value) public whenNotPaused returns (bool) {
return super.transfer(_to, _value);
  }

   function transferFrom(address _from, address _to, uint256 _value) public whenNotPaused returns (bool) {
return super.transferFrom(_from, _to, _value);
   }

  function approve(address _spender, uint256 _value) public whenNotPaused returns (bool) {
return super.approve(_spender, _value);
  }

  function increaseApproval(address _spender, uint _addedValue) public whenNotPaused returns (bool success) {
return super.increaseApproval(_spender, _addedValue);
  }

   function decreaseApproval(address _spender, uint _subtractedValue) public whenNotPaused returns (bool success) {
return super.decreaseApproval(_spender, _subtractedValue);
 }
}

contract Test is StandardToken, PausableToken {
   string public constant name = 'Test';                                      // Set the token name for display
   string public constant symbol = 'TEST';                                       // Set the token symbol for display
   uint8 public constant decimals = 18;                                          // Set the number of decimals for display
   uint256 public constant INITIAL_SUPPLY = 50000000000 * 10**uint256(decimals);  // 50 billions 

  function Test() public{
totalSupply = INITIAL_SUPPLY;                               // Set the total supply
balances[msg.sender] = INITIAL_SUPPLY;                      // Creator address is assigned all
emit Transfer(0x0, msg.sender, INITIAL_SUPPLY);
  }

   function transfer(address _to, uint256 _value) public whenNotPaused returns (bool) {
require(_to != address(0));
return super.transfer(_to, _value);
   }

   function transferFrom(address _from, address _to, uint256 _value) public whenNotPaused returns (bool) {
require(_to != address(0));
return super.transferFrom(_from, _to, _value);
   }

  function approve(address _spender, uint256 _value) public whenNotPaused returns (bool) {
return super.approve(_spender, _value);
  }

    event Burn(address indexed _burner, uint _value);

    function burn(uint _value) public returns (bool)
{
    balances[msg.sender] = balances[msg.sender].sub(_value);
    totalSupply = totalSupply.sub(_value);
    emit Burn(msg.sender, _value);
    emit Transfer(msg.sender, address(0x0), _value);
    return true;
    }
 }
Könnten Sie Ihren Token-Solidity-Quellcode bereitstellen?
Ich habe meinen Beitrag editiert :)

Antworten (1)

Dies ist ein vorübergehendes Problem mit der API von Etherscan, da die Token-Inhaber-Prozent-API anscheinend derzeit für die Ropsten & Kovan-Testnetze nicht verfügbar ist. Sie können dies überprüfen, indem Sie auch andere Token-Verträge in diesen Netzwerken überprüfen.

Ihr Vertrag implementiert alle erforderlichen ERC-20-Funktionen korrekt.

Sie sollten entweder warten, bis der Dienst wieder betriebsbereit ist, oder versuchen, Ihren Vertrag im Rinkeby-Testnetz bereitzustellen, wo die API ordnungsgemäß funktioniert.

Ja, aber es sieht so aus, als hätte der Vertrag eine uint256 public totalSupplyFeldvariable und solidity erstellt automatisch eine Getter-Methode mit demselben Namen dafür.
Danke für deine Antwort. Ich muss diese Funktion nach der Funktion "function Test() public" setzen?
Während @DmytroZarezenko richtig ist, wird es mit 0 initialisiert, da es nie neu zugewiesen INITIAL_SUPPLYwird und nur die tatsächliche Gesamtversorgung zugewiesen wird.
@yohan Versuchen Sie, den INITIAL_SUPPLYVariablennamen in zu ändern, totalSupplyund entfernen Sie die Zuweisung aus dem Test()Funktionskörper.
@AlexPapageorgiou, aber wir haben totalSupply = INITIAL_SUPPLY;Anweisungen im TestVertragskonstruktor.
@DmytroZarezenko Das ist mir aufgefallen, weshalb ich vorgeschlagen habe, die Zuweisung zu entfernen. Die Spezifikation selbst erfordert, dass die Funktion konstant ist ( auch wenn es beim Aufrufen der Funktion über RPC keine Rolle spielt ), also vermasselt der Compiler möglicherweise etwas an der Zuweisung.
@alex Papageorginou kannst du mir bitte den Funktionstest schreiben. Ich bin ein bisschen verloren..
@yohan Ich habe meine Antwort geändert, es scheint, dass die Etherscan-Token-Halter-API derzeit für Ropsten und Kovan nicht verfügbar ist.