栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > asp

asp.net 2.0里也可以用JSON的使用方法

asp 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

asp.net 2.0里也可以用JSON的使用方法

全部代码如下。 
复制代码 代码如下:
///
/// JSON解析类
///

public static class JSonConvert
{
#region 全局变量

private static JSonObject _json = new JSonObject();//寄存器
private static readonly string _SEMIcolon = "@semicolon";//分号转义符
private static readonly string _COMMA = "@comma"; //逗号转义符

#endregion

#region 字符串转义
///
/// 字符串转义,将双引号内的:和,分别转成_SEMIcolon和_COMMA
///

///
///
private static string StrEncode(string text)
{
MatchCollection matches = Regex.Matches(text, "\"[^\"]+\"");
foreach (Match match in matches)
{
text = text.Replace(match.Value, match.Value.Replace(":", _SEMIcolon).Replace(",", _COMMA));
}

return text;
}

///
/// 字符串转义,将_SEMIcolon和_COMMA分别转成:和,
///

///
///
private static string StrDecode(string text)
{
return text.Replace(_SEMIcolon, ":").Replace(_COMMA, ",");
}

#endregion

#region JSON最小单元解析

///
/// 最小对象转为JSonObject
///

///
///
private static JSonObject DeserializeSingletonObject(string text)
{
JSonObject jsonObject = new JSonObject();

MatchCollection matches = Regex.Matches(text, "(\"(?[^\"]+)\":\"(?[^,\"]+)\")|(\"(?[^\"]+)\":(?[^,\"\}]+))");
foreach (Match match in matches)
{
string value = match.Groups["value"].Value;
jsonObject.Add(match.Groups["key"].Value, _json.ContainsKey(value) ? _json[value] : StrDecode(value));
}

return jsonObject;
}

///
/// 最小数组转为JSonArray
///

///
///
private static JSonArray DeserializeSingletonArray(string text)
{
JSonArray jsonArray = new JSonArray();

MatchCollection matches = Regex.Matches(text, "(\"(?[^,\"]+)")|(?[^,\[\]]+)");
foreach (Match match in matches)
{
string value = match.Groups["value"].Value;
jsonArray.Add(_json.ContainsKey(value) ? _json[value] : StrDecode(value));
}

return jsonArray;
}

///
/// 反序列化
///

///
///
private static string Deserialize(string text)
{
text = StrEncode(text);//转义;和,

int count = 0;
string key = string.Empty;
string pattern = "(\{[^\[\]\{\}]+\})|(\[[^\[\]\{\}]+\])";

while (Regex.IsMatch(text, pattern))
{
MatchCollection matches = Regex.Matches(text, pattern);
foreach (Match match in matches)
{
key = "___key" + count + "___";

if (match.Value.Substring(0, 1) == "{")
_json.Add(key, DeserializeSingletonObject(match.Value));
else
_json.Add(key, DeserializeSingletonArray(match.Value));

text = text.Replace(match.Value, key);

count++;
}
}
return text;
}

#endregion

#region 公共接口

///
/// 序列化JSONObject对象
///

///
///
public static JSonObject DeserializeObject(string text)
{
_json = new JSonObject();
return _json[Deserialize(text)] as JSONObject;
}

///
/// 序列化JSONArray对象
///

///
///
public static JSonArray DeserializeArray(string text)
{
_json = new JSonObject();
return _json[Deserialize(text)] as JSONArray;
}

///
/// 反序列化JSONObject对象
///

///
///
public static string SerializeObject(JSonObject jsonObject)
{
StringBuilder sb = new StringBuilder();
sb.Append("{");
foreach (KeyValuePair kvp in jsonObject)
{
if (kvp.Value is JSONObject)
{
sb.Append(string.Format(""{0}":{1},", kvp.Key, SerializeObject((JSONObject)kvp.Value)));
}
else if (kvp.Value is JSONArray)
{
sb.Append(string.Format(""{0}":{1},", kvp.Key, SerializeArray((JSONArray)kvp.Value)));
}
else if (kvp.Value is String)
{
sb.Append(string.Format(""{0}":"{1}",", kvp.Key, kvp.Value));
}
else
{
sb.Append(string.Format(""{0}":"{1}",", kvp.Key, ""));
}
}
if (sb.Length > 1)
sb.Remove(sb.Length - 1, 1);
sb.Append("}");
return sb.ToString();
}

///
/// 反序列化JSONArray对象
///

///
///
public static string SerializeArray(JSonArray jsonArray)
{
StringBuilder sb = new StringBuilder();
sb.Append("[");
for (int i = 0; i < jsonArray.Count; i++)
{
if (jsonArray[i] is JSONObject)
{
sb.Append(string.Format("{0},", SerializeObject((JSONObject)jsonArray[i])));
}
else if (jsonArray[i] is JSONArray)
{
sb.Append(string.Format("{0},", SerializeArray((JSONArray)jsonArray[i])));
}
else if (jsonArray[i] is String)
{
sb.Append(string.Format(""{0}",", jsonArray[i]));
}
else
{
sb.Append(string.Format(""{0}",", ""));
}

}
if (sb.Length > 1)
sb.Remove(sb.Length - 1, 1);
sb.Append("]");
return sb.ToString();
}
#endregion
}

///
/// 取出JSON对象类
///

public class JSonObject : Dictionary
{
public new void Add(string key, object value)
{
System.Type t = value.GetType();

if (t.Name == "String")
{
value = JsonEncode.StrEncodeForDeserialize(value.ToString());
}

base.Add(key, value);
}
}

///
/// 取出JSON数组类
///

public class JSonArray : List
{
public new void Add(object item)
{
System.Type t = item.GetType();

if (t.Name == "String")
{
item = JsonEncode.StrEncodeForDeserialize(item.ToString());
}

base.Add(item);
}
}

///
/// 字符串转义,将"{"、"}"、"""
///

public class JsonEncode
{
public static readonly string _LEFTBRACES = "@leftbraces";//"{"转义符
public static readonly string _RIGHTBRACES = "@rightbraces";//"}"转义符
public static readonly string _LEFTBRACKETS = "@leftbrackets";//"["转义符
public static readonly string _RIGHTBRACKETS = "@rightbrackets";//"]"转义符
public static readonly string _DOUBLEQUOTATIonMARKS = "@doubleQuotationMarks";//"""转义符


#region 字符串转义
///
/// 字符串转义,将"{"、"}"、""",分别转换_LEFTBRACES、_RIGHTBRACES、_DOUBLEQUOTATIonMARKS
///

///
///
public static string StrEncodeForDeserialize(string text)
{
return text
.Replace("{", _LEFTBRACES)
.Replace("}", _RIGHTBRACES)
.Replace("[", _LEFTBRACKETS)
.Replace("]", _RIGHTBRACKETS)
.Replace(""", _DOUBLEQUOTATIONMARKS);
}

///
/// 字符串转义,将_LEFTBRACES、_RIGHTBRACES、_DOUBLEQUOTATIONMARKS,分别转换"{"、"}"、"""
///

///
///
public static string StrDecodeForDeserialize(string text)
{
return text.Replace(_LEFTBRACES, "{")
.Replace(_RIGHTBRACES, "}")
.Replace(_LEFTBRACKETS, "[")
.Replace(_RIGHTBRACKETS, "]")
.Replace(_DOUBLEQUOTATIONMARKS, """);
}
#endregion
}

 最后要说的,就是比较马烦的是,现在要取JSON里的值要用到下面的方法复制代码 代码如下:
this.Label2.Text = JsonEncode.StrDecodeForDeserialize(json["domain"].ToString());
this.Label2.Text = JsonEncode.StrDecodeForDeserialize(((JSONArray)json["years"])[4].ToString());
转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号