json转换(c#后台生成json的方法)
此文转自:http://bbs.csdn.net/topics/380200497,为了方便自己记忆才以文章形式保存。
using
System;
using
System.Collections.Generic;
using
System.Text;
using
System.Data;
using
System.Reflection;
using
System.Collections;
using
System.Data.Common;
namespace
DotNet.Utilities
{
//JSON转换类
public
class
ConvertJson
{
#region 私有方法
/// <summary>
/// 过滤特殊字符
/// </summary>
private
static
string
String2Json(String s)
{
StringBuilder sb =
new
StringBuilder();
for
(
int
i = 0; i < s.Length; i++)
{
char
c = s.ToCharArray()[i];
switch
(c)
{
case
'\"'
:
sb.Append(
"\\\""
);
break
;
case
'\\'
:
sb.Append(
"\\\\"
);
break
;
case
'/'
:
sb.Append(
"\\/"
);
break
;
case
'\b'
:
sb.Append(
"\\b"
);
break
;
case
'\f'
:
sb.Append(
"\\f"
);
break
;
case
'\n'
:
sb.Append(
"\\n"
);
break
;
case
'\r'
:
sb.Append(
"\\r"
);
break
;
case
'\t'
:
sb.Append(
"\\t"
);
break
;
default
:
sb.Append(c);
break
;
}
}
return
sb.ToString();
}
/// <summary>
/// 格式化字符型、日期型、布尔型
/// </summary>
private
static
string
StringFormat(
string
str, Type type)
{
if
(type ==
typeof
(
string
))
{
str = String2Json(str);
str =
"\""
+ str +
"\""
;
}
else
if
(type ==
typeof
(DateTime))
{
str =
"\""
+ str +
"\""
;
}
else
if
(type ==
typeof
(
bool
))
{
str = str.ToLower();
}
else
if
(type !=
typeof
(
string
) &&
string
.IsNullOrEmpty(str))
{
str =
"\""
+ str +
"\""
;
}
return
str;
}
#endregion
#region List转换成Json
/// <summary>
/// List转换成Json
/// </summary>
public
static
string
ListToJson<T>(IList<T> list)
{
object
obj = list[0];
return
ListToJson<T>(list, obj.GetType().Name);
}
/// <summary>
/// List转换成Json
/// </summary>
public
static
string
ListToJson<T>(IList<T> list,
string
jsonName)
{
StringBuilder Json =
new
StringBuilder();
if
(
string
.IsNullOrEmpty(jsonName)) jsonName = list[0].GetType().Name;
Json.Append(
"{\""
+ jsonName +
"\":["
);
if
(list.Count > 0)
{
for
(
int
i = 0; i < list.Count; i++)
{
T obj = Activator.CreateInstance<T>();
PropertyInfo[] pi = obj.GetType().GetProperties();
Json.Append(
"{"
);
for
(
int
j = 0; j < pi.Length; j++)
{
Type type = pi[j].GetValue(list[i],
null
).GetType();
Json.Append(
"\""
+ pi[j].Name.ToString() +
"\":"
+ StringFormat(pi[j].GetValue(list[i],
null
).ToString(), type));
if
(j < pi.Length - 1)
{
Json.Append(
","
);
}
}
Json.Append(
"}"
);
if
(i < list.Count - 1)
{
Json.Append(
","
);
}
}
}
Json.Append(
"]}"
);
return
Json.ToString();
}
#endregion
#region 对象转换为Json
/// <summary>
/// 对象转换为Json
/// </summary>
/// <param name="jsonObject">对象</param>
/// <returns>Json字符串</returns>
public
static
string
ToJson(
object
jsonObject)
{
string
jsonString =
"{"
;
PropertyInfo[] propertyInfo = jsonObject.GetType().GetProperties();
for
(
int
i = 0; i < propertyInfo.Length; i++)
{
object
objectValue = propertyInfo[i].GetGetMethod().Invoke(jsonObject,
null
);
string
value =
string
.Empty;
if
(objectValue
is
DateTime || objectValue
is
Guid || objectValue
is
TimeSpan)
{
value =
"'"
+ objectValue.ToString() +
"'"
;
}
else
if
(objectValue
is
string
)
{
value =
"'"
+ ToJson(objectValue.ToString()) +
"'"
;
}
else
if
(objectValue
is
IEnumerable)
{
value = ToJson((IEnumerable)objectValue);
}
else
{
value = ToJson(objectValue.ToString());
}
jsonString +=
"\""
+ ToJson(propertyInfo[i].Name) +
"\":"
+ value +
","
;
}
jsonString.Remove(jsonString.Length - 1, jsonString.Length);
return
jsonString +
"}"
;
}
#endregion
#region 对象集合转换Json
/// <summary>
/// 对象集合转换Json
/// </summary>
/// <param name="array">集合对象</param>
/// <returns>Json字符串</returns>
public
static
string
ToJson(IEnumerable array)
{
string
jsonString =
"["
;
foreach
(
object
item
in
array)
{
jsonString += ToJson(item) +
","
;
}
jsonString.Remove(jsonString.Length - 1, jsonString.Length);
return
jsonString +
"]"
;
}
#endregion
#region 普通集合转换Json
/// <summary>
/// 普通集合转换Json
/// </summary>
/// <param name="array">集合对象</param>
/// <returns>Json字符串</returns>
public
static
string
ToArrayString(IEnumerable array)
{
string
jsonString =
"["
;
foreach
(
object
item
in
array)
{
jsonString = ToJson(item.ToString()) +
","
;
}
jsonString.Remove(jsonString.Length - 1, jsonString.Length);
return
jsonString +
"]"
;
}
#endregion
#region DataSet转换为Json
/// <summary>
/// DataSet转换为Json
/// </summary>
/// <param name="dataSet">DataSet对象</param>
/// <returns>Json字符串</returns>
public
static
string
ToJson(DataSet dataSet)
{
string
jsonString =
"{"
;
foreach
(DataTable table
in
dataSet.Tables)
{
jsonString +=
"\""
+ table.TableName +
"\":"
+ ToJson(table) +
","
;
}
jsonString = jsonString.TrimEnd(
','
);
return
jsonString +
"}"
;
}
#endregion
#region Datatable转换为Json
/// <summary>
/// Datatable转换为Json
/// </summary>
/// <param name="table">Datatable对象</param>
/// <returns>Json字符串</returns>
public
static
string
ToJson(DataTable dt)
{
StringBuilder jsonString =
new
StringBuilder();
jsonString.Append(
"["
);
DataRowCollection drc = dt.Rows;
for
(
int
i = 0; i < drc.Count; i++)
{
jsonString.Append(
"{"
);
for
(
int
j = 0; j < dt.Columns.Count; j++)
{
string
strKey = dt.Columns[j].ColumnName;
string
strValue = drc[i][j].ToString();
Type type = dt.Columns[j].DataType;
jsonString.Append(
"\""
+ strKey +
"\":"
);
strValue = StringFormat(strValue, type);
if
(j < dt.Columns.Count - 1)
{
jsonString.Append(strValue +
","
);
}
else
{
jsonString.Append(strValue);
}
}
jsonString.Append(
"},"
);
}
jsonString.Remove(jsonString.Length - 1, 1);
jsonString.Append(
"]"
);
return
jsonString.ToString();
}
/// <summary>
/// DataTable转换为Json
/// </summary>
public
static
string
ToJson(DataTable dt,
string
jsonName)
{
StringBuilder Json =
new
StringBuilder();
if
(
string
.IsNullOrEmpty(jsonName)) jsonName = dt.TableName;
Json.Append(
"{\""
+ jsonName +
"\":["
);
if
(dt.Rows.Count > 0)
{
for
(
int
i = 0; i < dt.Rows.Count; i++)
{
Json.Append(
"{"
);
for
(
int
j = 0; j < dt.Columns.Count; j++)
{
Type type = dt.Rows[i][j].GetType();
Json.Append(
"\""
+ dt.Columns[j].ColumnName.ToString() +
"\":"
+ StringFormat(dt.Rows[i][j].ToString(), type));
if
(j < dt.Columns.Count - 1)
{
Json.Append(
","
);
}
}
Json.Append(
"}"
);
if
(i < dt.Rows.Count - 1)
{
Json.Append(
","
);
}
}
}
Json.Append(
"]}"
);
return
Json.ToString();
}
#endregion
#region DataReader转换为Json
/// <summary>
/// DataReader转换为Json
/// </summary>
/// <param name="dataReader">DataReader对象</param>
/// <returns>Json字符串</returns>
public
static
string
ToJson(DbDataReader dataReader)
{
StringBuilder jsonString =
new
StringBuilder();
jsonString.Append(
"["
);
while
(dataReader.Read())
{
jsonString.Append(
"{"
);
for
(
int
i = 0; i < dataReader.FieldCount; i++)
{
Type type = dataReader.GetFieldType(i);
string
strKey = dataReader.GetName(i);
string
strValue = dataReader[i].ToString();
jsonString.Append(
"\""
+ strKey +
"\":"
);
strValue = StringFormat(strValue, type);
if
(i < dataReader.FieldCount - 1)
{
jsonString.Append(strValue +
","
);
}
else
{
jsonString.Append(strValue);
}
}
jsonString.Append(
"},"
);
}
dataReader.Close();
jsonString.Remove(jsonString.Length - 1, 1);
jsonString.Append(
"]"
);
return
jsonString.ToString();
}
#endregion
}
}
json转换(c#后台生成json的方法)的更多相关文章
- aspx后台生成json对象
json对象应用很广,有时,我们要把一些数据转化为json对象,就需要用到以下方法了. 1.使用Newtonsoft.Json.DLL (推荐使用) 下载地址:http://files.cnblogs ...
- 如何使用fastJson来解析JSON格式数据和生成JSON格式数据
由于项目用到了JSON格式的数据,在网上搜索到了阿里的fastjson比较好用,特此记录fastjson用法,以备以后查询之用. decode: 首先创建一个JSON解析类: public class ...
- json转换成dart类 JSON to Dart
json_to_dart的使用 如果我们得到一个特别复杂的JSON,有时候会无从下手开始写Model,这时候就可以使用一些辅助工具.我认为json_to_dart是比较好用的一个.它可以直接把json ...
- json转换工具类:json<===>list或者对象
public class JsonTools { /** * POJO 转 JSON */ public static String createJsonString(Object object) { ...
- C#中Json转换主要使用的几种方法!
这篇主要介绍2.4.第三种方法使用的比较局限,所以我没有深入学习. 第二种方法 我使用比较多的方式,这个方法是.NET内置的,使用起来比较方便 A.利用serializer获取json的泛型对象 利用 ...
- PHP中生成json信息的方法
<?php //php中生成json信息 //json_encode(数组/对象) $color = array('red','blue','green'); //[索引数组] echo jso ...
- atitit.XML类库选型及object 对象bean 跟json转换方案
atitit.XML类库选型及object 对象bean 跟json转换方案 1. XML类库可以分成2大类.标准的.这些类库通常接口和实现都是分开的 1 2. 常见的xml方面的方法 2 2.1. ...
- Android原生生成JSON与解析JSON
JSON数据是一种轻量级的数据交换格式,在Android中通常应用于client与server交互之间的传输数据.像如今在网上有非常多解析JSON数据的jar包,可是归根究竟用的都是Android原生 ...
- Ajax前台返回JSON数据后再Controller中直接转换成类型使用,后台接收json转成实体的方法
之前写过一篇记录文章,写的是将一个比较复杂的数据结构在前台组合起来后传递到后台. 当时并不太了解@RequestBody,也并没有使用js提供的JSON.stringify()方法 所有都是自己写的, ...
随机推荐
- eclipse反编译插件
eclipse翻译的插件很多,jadclipse 是其中一款.设置很简单. ①.下载net.sf.jadclipse_3.3.0.jar 官方网站:http://sourceforge.net/pro ...
- 【不积跬步,无以致千里】Linux下启动Oracle服务和监听程序
oracle数据库是重量级的,其管理非常复杂,将其在linux平台上的启动和关闭步骤整理一下. 安装完毕oracle以后,需要创建oracle系统用户,并在/home/oracle下面的.bash_p ...
- Custom Properties for Alert Description and Notification(PropertyBag)
Alert Description Variables: For event Rules: EventDisplayNumber (Event ID): $Data/Event ...
- HDU 5289 Assignment(2015 多校第一场二分 + RMQ)
Assignment Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total ...
- [React Native] Build a Separator UI component
In this lesson we'll create a reusable React Native separator component which manages it's own style ...
- IOS笔记 #pragma mark的用法
简单的来说就是为了方便查找和导航代码用的. 下面举例如何快速的定位到我已经标识过的代码. #pragma mark 播放节拍器 - (void) Run:(NSNumber *)tick { //.. ...
- js之createTextRange方法
createTextRange()方法作用: 主要是用来对一些文本对象进行操作.比如你有一大段文字,都在同一个P标签内,但是你只希望通过JS改变其中的一小部分,这时就可以用createTextRang ...
- Microsoft Office Visio Professional 2007密钥
Microsoft Office Visio Professional 2007 产品密钥: W2JJW-4KYDP-2YMKW-FX36H-QYVD8
- 命令行一键清除IE记录
清除Internet临时文件 RunDll32.exe InetCpl.cpl,ClearMyTracksByProcess 8 清除Cookies RunDll32.exe InetCpl.cpl, ...
- web前端开发前景怎么样?
对于web前端开发,对现今前端的发展,中国的发展还很落后,中国没有Jquery,没有Node.js,其中最主要的一点是,中国的前端比较封锁,大家都没有分享的觉悟.回头看看,那些发展比较快的行业.软件, ...