下面是我们想要拼接出来的JSON字符串,返回给前台

 {"success":"true","msg":"","data":[{"macName":"正面预拼装机","state":1.0},{"macName":"正面拼板压力架","state":1.0},{"macName":"板片翻身系统","state":1.0},{"macName":"反面预拼装机","state":1.0},{"macName":"反面拼板压力架","state":1.0},{"macName":"划线喷码机","state":0.0},{"macName":"纵骨焊接安装辊道","state":0.0},{"macName":"纵骨焊接机","state":1.0},{"macName":"T排焊接安装辊道","state":0.0}]}

  想看拼接后的JSON格式,这里可以推荐一个网站:https://www.json.cn/

  之前都是用StringBuider手动拼接出JSON数据,拼出来的结果还容易错,下面推荐一个简单方式

  首先,我们把JSON数组创建实体类,那么问题来了,这个实体类如何创建,这里推荐一个网站:http://www.bejson.com/convert/json2csharp/,只需要将JSON格式放入,就会帮我们自动转成实体类

  实体类也比较简单,用到了List集合存放对象,下面Demo演示

实体类

     public class MacState
{
/// <summary>
/// 请求状态
/// </summary>
public string success { get; set; }
/// <summary>
/// 错误信息
/// </summary>
public string msg { get; set; }
/// <summary>
/// JSON数组
/// </summary>
public List<MacStateData> data { get; set; }
}
public class MacStateData
{
/// <summary>
/// 设备名称
/// </summary>
public string macName { get; set; }
/// <summary>
/// 运行状态 运行/停止(1/0)
/// </summary>
public decimal state { get; set; }
}

函数(标红色的注意!!!)

     /// <summary>
/// 设备状态情况
/// </summary>
/// <returns>JSON数组</returns>
[WebMethod(Description ="设备状态")]
public string GetMacState()
{
MacState obj = new MacState();
try
{
DateTime NowDate = DateTime.Now;
DataTable dt_his_count = new DataTable();
DataTable dt_mac_state = new DataTable();
int max_count = ;
string add_his_sql = "INSERT INTO EMES_MAC_STATE_PORT_HIS (DEF_DATE) VALUES (TO_DATE('{0}','YYYY-MM-DD HH24:MI:SS'))";
DbUtil.ExecuteSql(string.Format(add_his_sql, NowDate));
string query_his_sql = "SELECT COUNT(*) FROM EMES_MAC_STATE_PORT_HIS";
dt_his_count = DbUtil.QueryDT(query_his_sql);
if (Convert.ToDecimal(dt_his_count.Rows[][]??"")>max_count) //接口日志超过20W条,自动删除
{
string del_sql = "DELETE FROM EMES_MAC_STATE_PORT_HIS";
DbUtil.ExecuteSql(del_sql);
}
string query_mac_state_sql = "SELECT MAC_NAME,STATE FROM EMES_MAC_STATE";
dt_mac_state = DbUtil.QueryDT(query_mac_state_sql);
if (dt_mac_state.Rows.Count > )
{
obj.success = "true";
obj.msg = "";
obj.data = new List<MacStateData>(); //实例化JSON数组,不实例化要报错
for (int i = ; i < dt_mac_state.Rows.Count; i++)
{
MacStateData objData = new MacStateData(); //实例化JSON数组对象,用于添加JSON数组集合
objData.macName = dt_mac_state.Rows[i]["MAC_NAME"].ToString();
objData.state = Convert.ToDecimal(dt_mac_state.Rows[i]["STATE"] ?? "");
obj.data.Add(objData); //添加JSON数组集合
}
string res = JsonConvert.SerializeObject(obj); //转JSON数组,演示用,下面讲方法使用
return JSONHelper.ToJSON(obj); //调用的封装函数,不用管,我们将上面的方式
}
else
{
obj.success = "false";
obj.msg = "当前无数据信息,请稍后再试!";
obj.data = new List<MacStateData>();
return JSONHelper.ToJSON(obj);
}
}
catch (Exception ex)
{
obj.success = "false";
obj.msg = ex.Message;
obj.data = new List<MacStateData>();
return JSONHelper.ToJSON(obj);
}
}

注:将对象转JSON数组,我们需要引入外部类库:Newtonsoft.Json.dll,没有的小伙伴请到我另外一篇博客下载:https://www.cnblogs.com/chenyanbin/p/11200415.html

 引入命名空间:
using Newtonsoft.Json; 方法使用:
JsonConvert.SerializeObject(实体类对象)

JSON数组

搞定~~

C#拼装JSON数组简易方法的更多相关文章

  1. js便利json 数组的方法

    这篇文章主要介绍了JQuery遍历json数组的3种方法,本文分别给出了使用each.for遍历json的方法,其中for又分成两种形式,需要的朋友可以参考下 $(function () { var ...

  2. Jsp页面用ajax传输json数组的方法

    详细参考jquery的API 这里主要展示实例,即写法 <%@ page language="java" contentType="text/html; chars ...

  3. 浅谈thinkphp中将字符串转换成json数组的方法

    这是一部分代码: $client = M("Client");$data = $client->where('user_id ='.$user_id)->select( ...

  4. ajax交互数据简单拼装,数组成字符串

    json2Form:function(json) { var str = ""; for(var p in json){ // 判断对象是否为数组 if(typeof json[p ...

  5. Gson应用:利用map和list来拼装Json消息

    import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; i ...

  6. JS简单循环遍历json数组的方法

    例如数据库里面的json字符串是这样的 1 2 3 4 5 var str = '[{"name":"宗2瓜","num":"1& ...

  7. json 拼二维json数组

    js声明数组 以及向数组中添加as移除json数据 JavaScript声明JSON数组的方法: //部分条件,在数据渲上数据要求是数组格式而非json数组格式,取arrayJson.dataList ...

  8. jsoncpp解析拼装数组

    Cocos2d-x添加jsoncpp应该资料都有了,今天来讲讲数组的解析和拼装- int main() { 数组创建与分析: 例子一: string strValue = "{\" ...

  9. java递归算法实现拼装树形JSON数据

    有时候页面需要使用jQuery easy ui中的combotree,需要给combotree提供一个JSON数据,使用如下方法(递归)实现(下面是dao层的实现层): /** * 根据表名和父id拼 ...

随机推荐

  1. 编译时MSIL注入--实践Mono Cecil(1)

    原文:编译时MSIL注入--实践Mono Cecil(1) 紧接上两篇浅谈.NET编译时注入(C#-->IL)和浅谈VS编译自定义编译任务—MSBuild Task(csproject),在第一 ...

  2. SQL Server根据字段查询不出记录

    今天写了一条select语句,很奇怪的一件事,我写程序几年了,第一次碰到这个问题,就是数据库里有这个值,你根据这个值查询就是查询不出来这行记录. 所以我想是不是里面有空格,回车什么的,最后果然如此. ...

  3. MessageBox用法大全

    //1.显示提示信息 MessageBox.Show("Hello World!"); //2.给消息框加上标题 MessageBox.Show("Hello World ...

  4. DataTable 更改在有数据列的类型方法

    原文:DataTable 更改在有数据列的类型方法 /// <summary> /// 修改数据表DataTable某一列的类型和记录值(正确步骤:1.克隆表结构,2.修改列类型,3.修改 ...

  5. Android卡片设置透明度失效问题

    最近在做蓝牙电话项目,需要支持双路通话,涉及到通话卡片透明度调节,当正在通话中,有新的来电时,原来的通话卡片需要做成30%的透明度,本来很简单的一个小改进,但通过 setAlpha()接口总是失效!  ...

  6. 麻省理工的 Picture 语言:代码瘦身的秘诀

    直击现场 如今,机器学习算法已经进入了主流的计算机,而麻省理工学院正在研究一款让每日的编程变得更加简单的技术. MIT 研究者将在六月发布一款新的叫做 Picture 的编程语言,当计算机在视频或者图 ...

  7. 在DBGrid增加一列CheckBox(而非DBCheckBox)

    自:http://rabbitfox.blog.sohu.com/33264033.html http://community.csdn.net/Expert/topic/5342/5342920.x ...

  8. 【canvas】高级功能一 变形

    [canvas]Demo1 scale缩放 <!DOCTYPE html> <html lang="en"> <head> <meta c ...

  9. Spectre小计

    今天安装了vs2017,而后又安装了wdk,随便写了一个控制台测试程序,居然报错.网上也查了一圈,也没有得到解决.报错内容如下: MSB8038:已启用Spectre缓解,但找不到Spectre缓解库 ...

  10. XP下安装ubuntu

    一,环境说明 dell vostro 1400笔记本,winxp sp3操作系统,ubuntu-9.10-desktop-i386.iso 写这篇随笔的时候我用的已经是ubuntu了. 我是在我的移动 ...