Java +本地消息传递并不好用

时间:2015-06-19 01:03:01

标签: google-chrome native messaging npapi

由于NPAPI已弃用,我的Java应用程序和Google Chrome存在问题。 阅读一些文章和博客,我发现了一个"解决方案" : Native Messaging

但是所有的例子都是用C ++ / C#/ Python制作的,对于Java来说,没有什么...... 我想如果有人可以帮我这个..

这是我的架构(see image): Google Chrome扩展程序 - >原生消息 - > Java App(jar)

问题: 扩展程序调用Java应用程序,Java应用程序运行但没有收到任何内容,当它返回时,没有任何内容可以扩展。

这是我的代码:

  

Chrome扩展程序

background.js



chrome.runtime.onConnect.addListener(function(port) {

port.onMessage.addListener(
  function(message) {	
	chrome.tabs.query({active: true, currentWindow: true}, function(tabs) {
		console.log( 'background.js received msg [' + message.text + ']'); 
		console.log( 'port.postMessage({content: "generated by background.js"}); to [' + tabs[0].id + "/" + tabs[0].url + ']');
		chrome.runtime.sendNativeMessage('cnb.digitalsigning',message,function(response) {
    console.log("Received from native " + response);
  });
	
		chrome.tabs.sendMessage(tabs[0].id, {content: "generated by background.js"});
	});
	return true;
  });  
  
port.onDisconnect.addListener(function() {
  console.log("Background.js Port disconnected");
});

});

  //native messaging




content_script.js



window.addEventListener("message", function(event) {
  // We only accept messages from ourselves
  
  if (event.source != window)
    return;

  if (event.data.type && (event.data.type == "DIGITAL_SIGNER_MSG")) {
    console.log("Content script received  from webpage: " + event.data.text);
	console.log('calling port.postMessage(event.data.text); ...' + event.data.text );
	port = chrome.runtime.connect();	
	port.postMessage({text: event.data.text});
  }
}, false);


chrome.runtime.onMessage.addListener(
  function(response, sender, sendResponse) {
	alert("receiving response from extension" + response.content );  
});
 




的manifest.json



{
  "name": "Test",
  "description": "Test",
  "version": "0.1",
  "manifest_version": 2,
  "background": {
		"persistent" : true,
      "scripts": ["background.js"]	  
  },
  "content_scripts": [
    {
      "matches": ["*://*/*"],
      "js": ["content_script.js"]
    }
  ],
  "permissions": [
           "nativeMessaging"
        ]
}




  

HTML



<html>
<script>
function myFunc(){

	console.log('call func');
	window.postMessage({ type: "DIGITAL_SIGNER_MSG", text: "do it, baby!" }, "*");
	console.log('func called');
}


</script>
<body>
<div>Page</div>

<form>
<button  id="caller" onclick="myFunc()">Call Extension</button>
<div id="reponseDiv" style="border: 3px; border-color: blue;">NO RESPONSE LOADED</div>
</form>
</body>

</html>
&#13;
&#13;
&#13;

  

主机

installReg.bat

&#13;
&#13;
REG ADD "HKCU\Software\Google\Chrome\NativeMessagingHosts\digitalsigning" /ve /t REG_SZ /d "%~dp0digitalsigning.json" /f

pause
&#13;
&#13;
&#13;

launch.bat

&#13;
&#13;
C:\location\to\Java\jre\bin\java.exe -cp C:\component\target\java.jar com.org.App
pause
&#13;
&#13;
&#13;

digitalsigning.json

&#13;
&#13;
{
  "name": "digitalsigning",
  "description": "digitalsigning",
  "path": "c:\\place\\launch.bat",
  "type": "stdio",
  "allowed_origins": [
    "chrome-extension://<GOOGLE EXTENSION ID GENERATED>/"
  ]
}
&#13;
&#13;
&#13;

该应用程序包含一个Main,它使用System.in.read捕获邮件,并使用System.out.write响应扩展名。

我怎么能做这个沟通? 这是启动Java应用程序的正确方法吗?

2 个答案:

答案 0 :(得分:0)

https://stackoverflow.com/a/25617143/865284,您可以看到如何以正确的方式发送数据。 System.in应该是正确的方法,但到现在为止,我还没有找到一种在java中接收数据的方法。

答案 1 :(得分:0)

另请注意这篇文章,其中仅使用几行简单的代码行成功发送已发送和已返回的消息:https://stackoverflow.com/a/33113627。它应该清楚说明返回消息的基本要求是什么。