1

我正在与Ethereum, javascript, web3.js, geth,合作bootstrap 3。功能就像,当交易发生时,blockchain它必须提示输入帐户解锁密码。

我已经完成了下面的代码,但问题是,它将密码显示为文本,所以现在我想制作一个接受密码的自定义提示。

我也尝试过使用bootbox.js,但由于同步问题,它没有成功。即,在调用提示之前它给出“帐户已锁定”,不等待用户输入密码。

我想使用“bootbox.js”中的一些交互式提示来获取密码并等待用户输入,然后使用该输入解锁帐户,然后进行交易。

这就是我所做的

function unlockAccount(){
    var accounts = web3.eth.accounts;
    var passPhrase = prompt("Enter the passPhrase",'');
    web3.personal.unlockAccount(accounts[0],passPhrase);

}

如果您需要任何进一步的细节,请在投反对票之前询问。谢谢

4

1 回答 1

0

试试这个(对我来说就像一个魅力):

var promptCount = 0;
    window.pw_prompt = function (options) {
      var lm = options.lm || "Password:",
        bm = options.bm || "Submit";
      if (!options.callback) {
        alert("No callback function provided! Please provide one.")
      };

      var prompt = document.createElement("div");
      prompt.className = "pw_prompt";

      var submit = function () {
        options.callback(input.value);
        document.body.removeChild(prompt);
      };

      var label = document.createElement("label");
      label.textContent = lm;
      label.for = "pw_prompt_input" + (++promptCount);
      prompt.appendChild(label);

      var input = document.createElement("input");
      input.id = "pw_prompt_input" + (promptCount);
      input.type = "password";
      input.addEventListener("keyup", function (e) {
        if (e.keyCode == 13) submit();
      }, false);
      prompt.appendChild(input);

      var button = document.createElement("button");
      button.textContent = bm;
      button.addEventListener("click", submit, false);
      prompt.appendChild(button);

      document.body.appendChild(prompt);
      document.getElementById(input.id).focus()
    };

pw_prompt({        
        lm: 'Enter Password to load your identity',
        bm: 'Load',
        callback: function (password) {     
          web3.personal.unlockAccount(accounts[0], password);
      }});
.pw_prompt {
        position: fixed;
        left: 50%;
        top: 50%;
        margin-left: -150px;
        padding: 15px;
        /* width: 263px; */
        border: 1px solid black;
        background: darkgrey;
    }
.pw_prompt label {
  display:block; 
  margin-bottom:5px;
}
.pw_prompt input {
  width:300px;
  margin-bottom:10px;
}

于 2016-12-22T16:23:44.717 回答