我正在使用带有本地主机消息传递的Chrome扩展程序。我无法在主机应用程序中使用消息文本。从建立连接一切正常工作,以获得扩展响应。 我需要在我的应用程序中使用Message文本,以便在简单的文本数据类型(string / char)中进一步使用/执行。我知道消息是UTF8编码形式我试图解码但仍然有问题,任何人都可以帮助我吗?
当我解码消息chrome扩展控制台时显示错误:"与本机消息传递主机通信时出错。"如果我在" cout"之后使用该消息文本与本机消息传递主机通信时出现相同的错误"错误"。直接发送和接收消息对我来说很好。
代码是这样的:
std::string mycode(std::string data){
data= data+"abc"; //changing text to any thing.
cout<< data;
anotherFunction(data);//killing processes using string data
}
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 = "";
std::cin.read((char*)&inMsgLen, 4);
if (inMsgLen == 0)
{
break;
}
else
{
for (int i=0; i < inMsgLen; i++)
{
ch = getchar();
input += ch;
}
}
response.append("{\"echo\":").append(input).append("}");
outMsgLen = response.length();
std::cout.write((char*)&outMsgLen, 4);
std::cout << response;
cout<< input;
//using "input" variable for further user
mycode(input);
}
return 0;
}
答案 0 :(得分:1)
那是错的,你读过这些文档吗? 尝试这样的事情......
_setmode( _fileno( stdin ), _O_BINARY );
_setmode( _fileno( stdout ), _O_BINARY );
char cBuffer[65536] = {0};
while(true)
{
unsigned int uiSize = 0;
std::cin.read((char*)&uiSize, sizeof(unsigned int));
if(uiSize != 0 && uiSize < 65536)
{
memset(cBuffer, 0, 65536);
std::cin.read(cBuffer, uiSize);
std::string strIn(cBuffer);
std::string strOut = "{\"result\":\"This is a Test\"}";
uiSize = strOut.length();
std::cout << char(((uiSize>>0) & 0xFF));
std::cout << char(((uiSize>>8) & 0xFF));
std::cout << char(((uiSize>>16) & 0xFF));
std::cout << char(((uiSize>>24) & 0xFF));
std::cout << strOut.c_str();
}
else
break;
}
你需要将io设置为二进制,否则这样的事情可能会发生...... 如果存在值为00011010(CTRL ALT Z = 26)的字节,则将其视为EOF并结束通信。 :)