文章目录
一个简单的jsoncpp转换类
qt下使用 jsoncpp 设计的 JsonParse 对象
class JsonParse
{
public:
JsonParse(Json::Value J)
:m_json(J)
{};
JsonParse(const void *V)
:m_str(V ? (const char*)V : "")
{};
JsonParse(const char *S)
:m_str(S ? S : "")
{};
JsonParse(const char *S, int L)
:m_str(S ? S : "", S ? L : 0)
{};
JsonParse(std::string S)
:m_str(S)
{};
virtual ~JsonParse(){};
public:
std::string toString(const char* indent="")
{
if(m_json.isObject() && m_json.getMemberNames().size() == 0)
return "";
else if(m_json.isString())
return m_json.asString();
Json::StreamWriterBuilder builder;
if(indent)
builder["indentation"] = indent; //The JSON document is written in a single line if indent == ""
return Json::writeString(builder, m_json);
};
const char* toCString(const char* indent="")
{
m_str = toString(indent);
return m_str.c_str();
};
bool toJson(Json::Value &J)
{
bool ret = false;
JSONCPP_STRING errs;
Json::CharReaderBuilder builder;
Json::CharReaderBuilder::strictMode(&builder.settings_);
//builder["collectComments"] = false; // true = 允许在反序列化的时候保存注释,然后在序列化的时候写回注释
Json::CharReader* reader = builder.newCharReader();
ret = reader->parse(m_str.data(), m_str.data() + m_str.size(), &J, &errs);
if(!ret || !errs.empty())
qDebug()<<"error、"<<endl;
if(reader){delete reader;reader = NULL;}
return ret;
}
std::string formatMinSize()
{
/*
* 仅支持构造入参为字符串的形式
* 如果是Json::Value的构造形式,可以直接格式化成指定的indent
*/
if(!m_str.empty())
toJson(m_json);
return toString();
}
private:
std::string m_str;
Json::Value m_json;
};
简单使用
QByteArray data = request.readBody();
Json::Value urlResp;
JsonParse(data.toStdString()).toJson(urlResp);
qDebug()<<"string:" <<QString(urlResp["string"].asCString()) <<endl;