javascript - 如何在 html 页面中使用从 native 应用程序接收的数据?

标签 javascript google-chrome-extension extension-methods chrome-native-messaging

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

这是我的 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 的值?

最佳答案

从 native 应用程序获取数据后,您必须使用 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"]);
}

关于javascript - 如何在 html 页面中使用从 native 应用程序接收的数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50780758/

相关文章:

c# - 扩展方法 ConvertAll

c# - 扩展枚举,矫枉过正?

javascript - 使用 HTML 快速更新 RSS 阅读器?

javascript - 如何检查复选框是否已使用JavaScript?

google-chrome-extension - 错误的 Chrome 扩展程序提交审核 - 如何停止?

google-chrome-extension - Chrome 扩展程序中的更改响应

google-chrome-extension - chrome.tabs.executeScript 不工作?

c# - 为什么允许空对象上的扩展方法?

javascript - SSRS中的Javascript无法正确处理数字符号

javascript - highcharts 的背景颜色