Родное сообщение для расширения Windows Chrome может получить только первый ответ
Я пытаюсь использовать собственный обмен сообщениями для отправки некоторых данных в мое собственное приложение Windows. Он хорошо работает с методом runtime.sendNativeMessage(). Когда я пытаюсь использовать долгоживущие соединения, использующие порт, он также может передавать данные из chrome в мое приложение. Тем не менее, расширение Chrome может получить только первый ответ от моего приложения. Я уверен, что порт все еще открыт, потому что мое приложение все еще может получать данные из Chrome. Ниже приведен мой код:
Сценарий расширения Chrome:
var port = chrome.runtime.connectNative('com.mydomain.app1');
port.onMessage.addListener(function(msg) {
console.log("Received from port:", msg);
});
port.onDisconnect.addListener(function() {
console.log("Disconnected");
});
chrome.tabs.onUpdated.addListener(
function(tabId, changeInfo, tab) {
var param = {};
param['url'] = tab.url;
port.postMessage( param);
}
}
Мое приложение для Windows на C++:
int _tmain(int argc, _TCHAR* argv[])
{
while( true )
{
//read the first four bytes (=> Length)
unsigned int length = 0;
for (int i = 0; i < 4; i++)
{
char c;
if( ( c=getchar()) != EOF)
length += c<<i*8;
else return 0;
}
//read the json-message
std::string msg = "";
for (int i = 0; i < length; i++)
{
msg += getchar();
}
//.... do something
//send a response message
std::string message = "{\"text\": \"This is a response message\"}";
unsigned int len = message.length();
// We need to send the 4 bytes of length information
std::cout << char(((len>>0) & 0xFF))
<< char(((len>>8) & 0xFF))
<< char(((len>>16) & 0xFF))
<< char(((len>>24) & 0xFF));
// Now we can output our message
std::cout << message.c_str();
std::cout.flush();
}
}
Обратите внимание, что последняя строка "std:: cout.flush ();", если я ее закомментирую, даже первый ответ не будет отображаться в chrome. Я просто не мог понять, как chrome читает из stdout приложения.
1 ответ
Попробуйте с автоматической промывкой - std::cout.setf( std::ios_base::unitbuf )
Кроме того, способ чтения / записи длины входных / выходных сообщений является неправильным и не подходит для длинных сообщений.
Этот код хорошо работает для меня:
int main(int argc, char* argv[])
{
std::cout.setf( std::ios_base::unitbuf );
while (true)
{
unsigned int ch, inMsgLen = 0, outMsgLen = 0;
std::string input = "", response = "";
// Read 4 bytes for data length
std::cin.read((char*)&inMsgLen, 4);
if (inMsgLen == 0)
{
break;
}
else
{
// Loop getchar to pull in the message until we reach the total length provided.
for (int i=0; i < inMsgLen; i++)
{
ch = getchar();
input += ch;
}
}
response.append("{\"echo\":").append(input).append("}");
outMsgLen = response.length();
// Send 4 bytes of data length
std::cout.write((char*)&outMsgLen, 4);
// Send the data
std::cout << response;
}
return 0;
}