Я пытаюсь вернуться ниже модели из моего метода API, но он возвращает пустой ответ.
[DataContract]
public class MasterData
{
public IEnumerable<PROFILE> lstProfile { get; set; }
public IEnumerable<COMPETENCE> lstCOMPETENCE { get; set; }
public IEnumerable<TB> lstTB { get; set; }
public MasterData() { }
}
Ответ:
<MasterData xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WB.Q.Models"/>
Когда я отлаживаю метод web api, я вижу, что ответ правильно сформирован в операторе return, но я не получаю его как ответ
Действие
[HttpGet]
[Route("api/Common/AllMasterData")]
public MasterData GetAllMasterData()
{
MasterData mstrData=new MasterData();
mstrData = Helper.GetAllMasterData();
return mstrData;
}
Вспомогательный метод
internal static MasterData GetAllMasterData()
{
MasterData masterData = new MasterData();
DataSet ds = DBHelper.GetData("aaa", null);
List<COMPETENCE> lstCompetence = new List<COMPETENCE>();
if (ds != null && ds.Tables.Count > 0)
{
foreach (DataRow drow in ds.Tables[0].Rows)
{
Adding in list
}
}
masterData.lstCOMPETENCE = lstCompetence;
ds = DBHelper.GetData("bbb", null);
List<PROFILE> lstPROFILE = new List<PROFILE>();
if (ds != null && ds.Tables.Count > 0)
{
foreach (DataRow drow in ds.Tables[0].Rows)
{
Adding in list
}
}
masterData.lstProfile = lstPROFILE;
ds = DBHelper.GetData("zzz", null);
List<TBSite> lstTBSite = new List<TBSite>();
if (ds != null && ds.Tables.Count > 0)
{
foreach (DataRow drow in ds.Tables[0].Rows)
{
Adding in list
}
}
masterData.lstTBSite = lstTBSite;
return masterData;
}
Если я удалю DataContract из Modal, я получаю сообщение об ошибке ниже:
The 'ObjectContent`1' type failed to serialize the response body for content type 'application/xml; charset=utf-8'.
Обязательно ли использовать DataContract и DataMember, если у нас есть коллекция объектов в качестве свойства?