Родное сообщение для расширения 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;
}
Другие вопросы по тегам