繁体   English   中英

在C#Web API中从Controller清空JSON响应

[英]Empty JSON Response from Controller in C# Web API

我正在学习如何在C#中构建Web API。

我正在测试我的控制器,但是我得到了一个空的JSON响应。

这是我的控制器

public class ClassInfoController : ApiController
{
    private ClassRepository classRepo = new ClassRepository();

    public IList<string> getClassListByTerm(string termID)
    {
        List<string> classList = classRepo.getClassListByTerm(termID);

        return classList;
    }

这是我的存储库类,它查询我的实体模型

public class ClassRepository : IClass
{

    private cet_databaseEntities db = new cet_databaseEntities();

    public List<string> getClassListByTerm(string termID)
    {
        List<string> result = (from t in db.classCodeLookup
                where t.termID == termID
                orderby t.@class ascending
                select t.@class).ToList<string>();

        return result;
    }
}

我已经调试了我的控制器,并且在进行API调用时,此存储库类不向控制器返回任何数据,即空list 但是,我感到困惑的原因是,当我在存储库类上使用以下测试代码时

public class ClassRepositoryTests
{
    ClassRepository testRepo = new ClassRepository();

    [TestMethod()]
    public void getClassListByTermTest()
    {
        List<string> output = testRepo.getClassListByTerm("316a");
        foreach (string className in output)
        {
            Console.WriteLine(className);
        }
    }
}

我从我期望的存储库类中获得结果。

我为什么遇到这个问题?

尝试向API方法添加属性

[HttpGet]
public List<string> getClassListByTerm([FromUri]string termID)

或者您可以使用另一个类对象来请求数据。 我的意思是

 public class TermData
 {
     //use if nessassry [JsonProperty("TermId")]
     public string TermId {get;set;}
 }

 [HttpGet]
 public List<string> getClassListByTerm([FromUri]TermData data)

我的问题是Visual Studio中的Web API项目提供的自动API文档告诉我,我应该使用以下命令从浏览器调用我的控制器: http://localhost:51520/api/ClassInfo?termID={316a} 我不知道,这意味着{}保留了316a - 我认为它们就像接收参数的方法签名中使用的括号一样,但我认为它们用于将list / json传递给方法(不相关)这个案例)。 这意味着当我的存储库查询运行时,它没有返回任何内容,因为我没有查找字符串{316a}

如果我使用以下地址调用API http://localhost:51520/api/ClassInfo?termID=316a它的工作原理是因为字符串316a被传递给查询。

谢谢你们。

我有一个继承自DynamicObject的类,它只返回空的JSON(而XML似乎正确返回)。

在我的情况下,我能够删除DynamicObject继承和JSON序列化开始工作。

//didn't serialize to json, but xml worked
public MyClass : DynamicObject, IMyClass { //... }

//works for json and xml
public MyClass : IMyClass { //... }

不幸的是,我没有机会研究为什么DynamicObject会破坏JSON序列化。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM