我正在使用Ethereumjavascriptweb3.jsgethbootstrap 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);

}


如果您需要更多详细信息,请在投反对票之前询问。
谢谢

最佳答案

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



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;
}

关于javascript - 如何使用自定义提示在以太坊中解锁账户?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40170210/

10-09 05:46
查看更多