如何在 html 页面中使用从本机应用程序接收的数据?

How do I use data received from native app in html page?

我使用本机消息扩展。我向本机应用程序发送一个字符串,因此在我的本机应用程序中对其进行加密并将加密的字符串发送到网页。

这是我的 content_script.js:

window.addEventListener("message", function(event)  {
  if (event.source == window &&
      event.data &&
      event.data.direction == "from-page-script") {
    alert("send");
    browser.runtime.sendMessage(event.data);
}
});



function Sign(challenge) {            
            var j_Data = {}
            j_Data["command"] = "sign";
            j_Data["challenge"] = challenge;
            var j_Text = JSON.stringify(j_Data)
            window.postMessage
                ({
                    direction: "from-page-script",
                    message: j_Text,
                }, "*");

            //response = document.getElementById("result").value;
        }


/*
Send a message to the page script.
*/
function messagePageScript(request) {
    var str_Text = request["text"];
    var j_Text = JSON.parse(strText);
    var str_Command = jText["command"];

    if(str_Command == "signed")
    {
        var str_Signed_Data = jText["signeddata"];

    }       
    }


browser.runtime.onMessage.addListener(function(request, sender, sendResponse) {
    messagePageScript(request);
});

它工作正常。

当我收到一条消息时 messagePageScript(request); 被调用。

如何在我的 html 页面中使用 str_Signed_Data 的值?

创建一个函数和return你想在html页面中反映的数据,并使用angular绑定方法绑定html页面中的数据

从本机应用程序获取数据后,您必须对 return 数据使用 JavaScript 回调。

function KeyA3_Sign(challenge, funcSign) {   
   ...

   kHandler = getResponse.bind(null, funcSign);
   window.addEventListener("message", kHandler);
   window.postMessage(jsonData, "*");
}

function getResponse(func, event) {
   console.log("Call Get response");    
   func(event.data["text"]);
}