您好,登錄后才能下訂單哦!
知識解讀
?????????????在Windows通過記事本打開的UTF-8編碼文件,默認會在保存的時候,往文件開頭多添加三個字節EF BB BF,表明文本的編碼方式是UTF-8,這種技術就叫做BOM(Byte Order Mark,就是字節序標記)。在Unix或者Linux操作系統中不會出現這種情況。如果該文本是ANSI格式編碼的,也沒有添加其他的字符。
文本內容讀取差異
帶有BOM的文本字節流
"锘縖\r\n{\r\n\t\"version\": \"1.0.0\",\r\n\t\"messagetype\": \"alarm\",\r\n\t\"cmdtype\": 10009,\r\n\t\"sn\":\"202039248932482934\"
不帶BOM的文本字節流
"[\r\n{\r\n\t\"version\": \"1.0.0\",\r\n\t\"messagetype\": \"alarm\",\r\n\t\"cmdtype\": 10009,\r\n\t\"sn\": \"202039248932482934\"
問題
?默認情況下傳遞帶有BOM的文本字節流給JsonCpp解析,肯定是解析不出來的,因為多了EF BB BF三個字節,所以需要將這三個字節從文本中剔除
代碼
?std::ifstream ifs;
?ifs.open(pFileName, std::ifstream::in | std::ifstream::binary);
?std::string str((std::istreambuf_iterator<char>(ifs)), std::istreambuf_iterator<char>());
?std::string strValidJson;
?if ((0xef == (unsigned char)str[0]) && (0xbb == (unsigned char)str[1]) && (0xbf == (unsigned char)str[2]))
?{
??strValidJson = str.substr(3, str.length() - 3);
?}
?else
?{
??strValidJson = str;
?}
?//開始解析Json文本
?Json::Reader reader;
?Json::Value root;
?if (NULL == reader.parse(strJson, root))?
{
ifstream.close();
return;
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。