MVC中Json的使用:Controller中Json的处理

一、当查询得到的数据符合前台要求,不需要做任何处理,直接DataList To Json 返回前台。

代码:
1  var allEntities = service.QueryByPage(this.GetSearchFilter(searchModel), "InsertedDateUtc  Descending", pageSize, searchModel.PageIndex + 1, out recordCount);
2  return Json(allEntities, JsonRequestBehavior.AllowGet);

前台得到的Json数据(两条记录)

[
    {
        "DocumentID": "61d09198-198e-403e-89a0-01b98402c8ca",
        "DocumentFileName": "189017.docx.pdf",
        "ContentType": "doc",
        "Size": 167228,
        "InsertedDateUtc": "/Date(1358762613167)/",
        "LastModifiedOnDataSource": "/Date(1358504490000)/",
        "UniqueIDOnDataSource": "189017",
        "IsActive": true,
        "HasBeenIndexed": true,
        "TradeProductID": "1e04dc4d-5a68-4982-ba88-170a3f6525f5",
        "HasProcessedForAlerts": false,
        "Congress": "ESMO-2012",
        "Authors": "Zi Ming Zhao",
        "CongressType": "Poster",
        "DocumentTitle": "立普妥-一级预防中的应用                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        ",
        "EntityState": 2,
        "EntityKey": {
            "EntitySetName": "Document",
            "EntityContainerName": "MVCExampleEntities",
            "EntityKeyValues": [
                {
                    "Key": "DocumentID",
                    "Value": "61d09198-198e-403e-89a0-01b98402c8ca"
                }
            ],
            "IsTemporary": false
        }
    },
    {
        "DocumentID": "a71ea30c-b544-41fa-b008-77adcf7a0250",
        "DocumentFileName": "189153.docx.pdf",
        "ContentType": "doc",
        "Size": 136195,
        "InsertedDateUtc": "/Date(1358762610573)/",
        "LastModifiedOnDataSource": "/Date(1358778247000)/",
        "UniqueIDOnDataSource": "189153",
        "IsActive": true,
        "HasBeenIndexed": true,
        "TradeProductID": "1e04dc4d-5a68-4982-ba88-170a3f6525f5",
        "HasProcessedForAlerts": false,
        "Congress": null,
        "Authors": null,
        "CongressType": null,
        "DocumentTitle": "立普妥-碾碎服用                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            ",
        "EntityState": 2,
        "EntityKey": {
            "EntitySetName": "Document",
            "EntityContainerName": "MVCExampleEntities",
            "EntityKeyValues": [
                {
                    "Key": "DocumentID",
                    "Value": "a71ea30c-b544-41fa-b008-77adcf7a0250"
                }
            ],
            "IsTemporary": false
        }
    }
]

二、当得到的数据不能满足前台需求,比如,我希望加入一个键值对存入总记录数,以方便做分页。

 
   两种方法:
       1、拼字符串,注意return 的是Content( ).

代码

var allEntities = service.QueryByPage(this.GetSearchFilter(searchModel), "InsertedDateUtc  Descending", pageSize, searchModel.PageIndex + 1, out recordCount);
          
           string json = JsonConvert.SerializeObject(allEntities);
           StringBuilder sb = new StringBuilder();
           sb.Append("{");
           sb.Append("\"total\"");
           sb.Append(":280,");
           sb.Append("\"rows\"");
           sb.Append(":");
           sb.Append(json);
           sb.Append("}");
  return Content(sb.ToString());
 
          或者直接用String:   string jsonString = "{'total':280,'rows':" + json + "}";  (此方法用easyui测试时,前台无法解析)。
           return Content(jsonString);

前台得到的Json数据

{
    "total": 280,
    "rows": [
        {
            "$id": "1",
            "DocumentID": "61d09198-198e-403e-89a0-01b98402c8ca",
            "DocumentFileName": "189017.docx.pdf",
            "ContentType": "doc",
            "Size": 167228,
            "InsertedDateUtc": "2013-01-21T18:03:33.167",
            "LastModifiedOnDataSource": "2013-01-18T18:21:30",
            "UniqueIDOnDataSource": "189017",
            "IsActive": true,
            "HasBeenIndexed": true,
            "TradeProductID": "1e04dc4d-5a68-4982-ba88-170a3f6525f5",
            "HasProcessedForAlerts": false,
            "Congress": "ESMO-2012",
            "Authors": "Zi Ming Zhao",
            "CongressType": "Poster",
            "DocumentTitle": "立普妥-一级预防中的应用 ",
            "EntityKey": {
                "$id": "2",
                "EntitySetName": "Document",
                "EntityContainerName": "MVCExampleEntities",
                "EntityKeyValues": [
                    {
                        "Key": "DocumentID",
                        "Type": "System.Guid",
                        "Value": "61d09198-198e-403e-89a0-01b98402c8ca"
                    }
                ]
            }
        },
        {
            "$id": "3",
            "DocumentID": "a71ea30c-b544-41fa-b008-77adcf7a0250",
            "DocumentFileName": "189153.docx.pdf",
            "ContentType": "doc",
            "Size": 136195,
            "InsertedDateUtc": "2013-01-21T18:03:30.573",
            "LastModifiedOnDataSource": "2013-01-21T22:24:07",
            "UniqueIDOnDataSource": "189153",
            "IsActive": true,
            "HasBeenIndexed": true,
            "TradeProductID": "1e04dc4d-5a68-4982-ba88-170a3f6525f5",
            "HasProcessedForAlerts": false,
            "Congress": null,
            "Authors": null,
            "CongressType": null,
            "DocumentTitle": "立普妥-碾碎服用 ",
            "EntityKey": {
                "$id": "4",
                "EntitySetName": "Document",
                "EntityContainerName": "MVCExampleEntities",
                "EntityKeyValues": [
                    {
                        "Key": "DocumentID",
                        "Type": "System.Guid",
                        "Value": "a71ea30c-b544-41fa-b008-77adcf7a0250"
                    }

 2、重新创建一个新Json对象,把数据装进去。然后返回前台。

var allEntities = service.QueryByPage(this.GetSearchFilter(searchModel), "InsertedDateUtc  Descending", pageSize, searchModel.PageIndex + 1, out recordCount);
   // 创建JsonResult对象。
           JsonResult j = new JsonResult()
           {
               Data = new
               {
                   total = recordCount,
                   rows = allEntities
               }
           };
           //以下两个参数可选,前台接收有问题时可加上试试
           // j.ContentType = "application/json";     
           //j.ContentEncoding = System.Text.Encoding.UTF8;
           //以下参数设置是否允许GET请求
           j.JsonRequestBehavior = JsonRequestBehavior.AllowGet;
           return j; //此处不能再用 return Json(j, JsonRequestBehavior.AllowGet);//方式,否则相当于把Json又转换了一遍Json,前台接收的数据如下(我用easyui测试时,前台无法解析)。

EasyUi环境下有问题的Json

{
    "ContentEncoding": null,
    "ContentType": null,
    "Data": {
        "total": 920,
        "rows": [
            {
                "DocumentID": "61d09198-198e-403e-89a0-01b98402c8ca",
                "DocumentFileName": "189017.docx.pdf",
                "ContentType": "doc",
                "Size": 167228,
                "InsertedDateUtc": "/Date(1358762613167)/",
                "LastModifiedOnDataSource": "/Date(1358504490000)/",
                "UniqueIDOnDataSource": "189017",
                "IsActive": true,
                "HasBeenIndexed": true,
                "TradeProductID": "1e04dc4d-5a68-4982-ba88-170a3f6525f5",
                "HasProcessedForAlerts": false,
                "Congress": "ESMO-2012",
                "Authors": "Zi Ming Zhao",
                "CongressType": "Poster",
                "DocumentTitle": "立普妥-一级预防中的应用                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        ",
                "EntityState": 2,
                "EntityKey": {
                    "EntitySetName": "Document",
                    "EntityContainerName": "MVCExampleEntities",
                    "EntityKeyValues": [
                        {
                            "Key": "DocumentID",
                            "Value": "61d09198-198e-403e-89a0-01b98402c8ca"
                        }
                    ],
                    "IsTemporary": false
                }
            },
            {
                "DocumentID": "a71ea30c-b544-41fa-b008-77adcf7a0250",
                "DocumentFileName": "189153.docx.pdf",
                "ContentType": "doc",
                "Size": 136195,
                "InsertedDateUtc": "/Date(1358762610573)/",
                "LastModifiedOnDataSource": "/Date(1358778247000)/",
                "UniqueIDOnDataSource": "189153",
                "IsActive": true,
                "HasBeenIndexed": true,
                "TradeProductID": "1e04dc4d-5a68-4982-ba88-170a3f6525f5",
                "HasProcessedForAlerts": false,
                "Congress": null,
                "Authors": null,
                "CongressType": null,
                "DocumentTitle": "立普妥-碾碎服用                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            ",
                "EntityState": 2,
                "EntityKey": {
                    "EntitySetName": "Document",
                    "EntityContainerName": "MVCExampleEntities",
                    "EntityKeyValues": [
                        {
                            "Key": "DocumentID",
                            "Value": "a71ea30c-b544-41fa-b008-77adcf7a0250"
                        }
                    ],
                    "IsTemporary": false
                }
            }
        ]
    },
    "JsonRequestBehavior": 0,
    "MaxJsonLength": null,
    "RecursionLimit": null
}

三 、最后一个Json数据查看工具,很方便。
JSON Viewer

posted on 2015-10-12 17:58  静以修身俭以养德  阅读(703)  评论(0编辑  收藏  举报

导航