0

现在我正在做一个测试 API 我正在使用 Postman 扩展来测试谷歌浏览器上的 POST 方法。我的本地服务器中有一个数据库,我正在使用带有框架 4.0 的 VS2010。

我的 API 现在的 GetByID 方法运行良好。

他们都会在每次请求发送新数据之前清除数据,但是当我发出 POST 请求时不会发生这种情况。

每次我提出请求时,先前的结果都会保留在那里(如果我更改请求的参数,结果的数量会保持不变,但数据会发生变化)。

private List<Employee> Employees = new List<Employee>();

SqlConnection con;
SqlDataAdapter da;
DataSet ds = new DataSet();

public IEnumerable<Employee> Post(string param1, string param2)
{
    ds.Clear();
    con = new SqlConnection("Server=xxxx; Database=x; Trusted_Connection=True;");
    da = new SqlDataAdapter("select * from Employee", con);           
    da.Fill(ds);

    foreach (DataRow dr in ds.Tables[0].Rows)
    {
        Employees.Add(new Employee() { 
                          FirstName = dr[0].ToString(), 
                          LastName = dr[1].ToString(), 
                          Id = int.Parse(dr[2].ToString()), 
                          Designation = dr[3].ToString() 
                     });

    }

    return Employees.Where(e => e.FirstName == param1)
                    .Where(e => e.LastName == param2);
}

我的员工控制器

static readonly EmployeeDetails repository = new EmployeeDetails();

[System.Web.Mvc.HttpPost]
public IEnumerable<Employee> Search(string param1, string param2)
{
    //Employee search = repository.Post(param1, param2);
    IEnumerable<Employee> search = repository.Post(param1, param2);
    if (search == null)
    {
        throw new HttpResponseException(HttpStatusCode.NotFound);
    }

    return search;
}

我已经玩了一整天了,没有找到任何解决问题的方法。任何人都可以帮忙吗?

谢谢

4

2 回答 2

0

这可能是因为缓存尝试在 post 方法上添加此属性

[OutputCacheAttribute(VaryByParam = "*", Duration = 0, NoStore = true)]
于 2014-03-26T10:48:13.403 回答
0

好的,伙计们,这是我在 stackoverflow 上发布的第二个问题,答案很简单而且很愚蠢。

变量Employees是一个全局变量,我没有清理它,我只清理数据集,每次它再次调用员工时。

我只需要添加Employees.Clear();

很抱歉浪费了时间:p

于 2014-03-27T12:37:33.417 回答