如何使用Automapper将poco映射到JSON

时间:2010-10-13 20:12:09

标签: json mapping automapper

在我的MVC 2应用程序中,我有一个调用Web服务的典型方法,构建一个JSON数据对象并将其返回到视图。

一切正常,但我想知道是否有办法使用Automapper进行映射,这样我就可以从控制器中删除丑陋的代码。提前致谢

这是我的行动方法

public virtual ActionResult AllErrors(string sidx, string sord, 
                                      int page=1, int rows=10)
    {
        var pageSize = rows;
        var pageNumber = page;
        var orderBy = string.Format("{0} {1}", sidx, sord);

        var result = errorService.GetPagedOpenErrors(pageSize, page, orderBy);
        var errors = new List<IngestionErrorDataContract>(result.IngestionErrors);
        var totalPages = (int) Math.Ceiling(result.TotalRows/(float) pageSize);

        int index = 0;
        var list = new List<object>();
        errors.ForEach(e => list.Add(
                                new {
                                        i = index++,
                                        cell = new[] 
                                        {
                                            e.IngestionErrorId.ToString(),
                                            e.RunId.ToString(),
                                            e.ProcessDate.ToShortDateString(),
                                            e.Status,
                                            e.ErrorDetails
                                        }
                                    }));

        var jsonData = new
                           {
                               total = totalPages,
                               page = pageNumber,
                               records = result.TotalRows,
                               rows = list.ToArray()
                           };

        return Json(jsonData, JsonRequestBehavior.AllowGet);
    }

1 个答案:

答案 0 :(得分:2)

我使用AutoMapper的ConstructUsing方法解决了它。 这是我的地图

public void CreateMap()
    {
        Mapper.CreateMap<List<IngestionErrorDataContract>, object[]>()
            .ConvertUsing(
                errors =>
                    {
                        int index = 0;
                        var list = new List<object>();
                        errors.ForEach(e => list.Add(
                            new
                                {
                                    i = index++,
                                    cell = new[]
                                               {
                                                   e.IngestionErrorId.ToString(),
                                                   e.RunId.ToString(),
                                                   e.ProcessDate.ToShortDateString(),
                                                   e.Status,
                                                   e.ErrorDetails
                                               }
                                }));
                        return list.ToArray();
                    });
    }

现在这是我的行动方法

public virtual ActionResult AllErrors(string sidx, string sord, int page=1, int rows=10)
    {
        var pageSize = rows;
        var pageNumber = page;
        var orderBy = string.Format("{0} {1}", sidx, sord);

        var result = errorService.GetPagedOpenErrors(pageSize, page, orderBy);
        var errors = new List<IngestionErrorDataContract>(result.IngestionErrors);
        var totalPages = (int) Math.Ceiling(result.TotalRows/(float) pageSize);

        var jsonData = new
                           {
                               total = totalPages,
                               page = pageNumber,
                               records = result.TotalRows,
                               rows = mapper.Map<List<IngestionErrorDataContract>,object[]>(errors)
                           };

        return Json(jsonData, JsonRequestBehavior.AllowGet);
    }

我认为好多了