1

我的 Web api 应用程序有问题。当我尝试在我的数据库中发布(保存)新用户时出现内部错误 500。下面的函数是我用来进行客户端调用的函数。

public void InsertNewUser(RegisterModel pNewUser, string pEmail)
{
    // Build rest uri
    string lREST_Uri_Browse = string.Format(@"api/accountapi/saveuserdata"
    // User data
    /*pModelSerialized*/);

    // Complete URI
    string lREST_Uri = Helpers_API.endPoint + lREST_Uri_Browse;

    var client = new HttpClient();

    client.BaseAddress = new Uri(Helpers_API.endPoint);

        var newUser = new Models.Models_API.Users
        {
            Email = pNewUser.Email,
            FName = pNewUser.FName,
            LName = pNewUser.LName,
            Inserted = DateTime.Now,
            ActiveAcc = true,
            AccType = pNewUser.AccType,
            BCompanyID = pNewUser.CompanyID,
            PID = pNewUser.PID,
            Password = pNewUser.Password,
            Token = GetToken(pEmail),
            ThirdParty = 0,
            Gender = pNewUser.Gender,
            BirthDate = pNewUser.BirthDate
        };

        // Add an Accept header for JSON format.
        //client.DefaultRequestHeaders.Accept.Add(
        //    new MediaTypeWithQualityHeaderValue("application/json"));
        // Create the JSON formatter.
        MediaTypeFormatter jsonFormatter = new JsonMediaTypeFormatter();

        // Use the JSON formatter to create the content of the request body.
        HttpContent content = new ObjectContent<Models.Models_API.Users>(newUser, jsonFormatter);

        var result = client.PostAsync(lREST_Uri_Browse, content).Result;
}

这是模型

public class Users
{
    public int BrokerID { get; set; }
    public DateTime Inserted { get; set; }
    public string Email { get; set; }
    public string FName { get; set; }
    public string LName { get; set; }
    public bool ActiveAcc { get; set; }
    public int BCompanyID { get; set; }
    public int PID { get; set; }
    public int AccType { get; set; }
    public string Password { get; set; }
    public string Token { get; set; }
    public int Gender { get; set; }
    public DateTime BirthDate { get; set; }
    public int ThirdParty { get; set; }
}

下面是 APIController 中的 POST:

public HttpResponseMessage SaveUserData(Users pNewUser)
    {
        bool createUser = false;
        // First check for provided email in DB
        Users existingUser = asigCtx.Users.Where(u => u.Email == pNewUser.Email).SingleOrDefault();
        if (existingUser == null)
            createUser = true;
        else if (existingUser.ActiveAcc)
            createUser = true;

        if (createUser)
        {
            using (asigCtx = new AsigPrimeContext())
            {
                Users user = new Users()
                {
                    Email = pNewUser.Email,
                    FName = pNewUser.FName,
                    LName = pNewUser.LName,
                    Inserted = DateTime.Now,
                    ActiveAcc = true,
                    AccType = pNewUser.AccType,
                    BCompanyID = pNewUser.BCompanyID,
                    PID = pNewUser.PID,
                    Password = pNewUser.Password,
                    Token = pNewUser.Token,
                    ThirdParty = 0,
                    Gender = pNewUser.Gender,
                    BirthDate = pNewUser.BirthDate,
                };

                asigCtx.Users.Add(user);

                asigCtx.SaveChanges();
            }
        }
        var response = Request.CreateResponse<Users>(HttpStatusCode.Created, pNewUser);
        return response;
    }

任何人都可以给我一些关于这段代码的建议,因为我是这方面的新手,我只想做到这一点。TNX

4

5 回答 5

3

您的代码中有错误。500 错误表示您的代码包含一个未处理的异常,该异常杀死了它的工作进程。

更改您的 web.config 文件,以便您的应用程序输出完整的错误消息。

于 2013-06-08T22:38:58.817 回答
1

我会检查/尝试解决问题的几件事:

  1. 上面的代码是否与您的应用程序中的代码完全相同,或者您是否更改了任何内容(即使只是为了使其更简单)?

  2. SaveUserData 控制器方法中使用的Users对象是否肯定来自与您从该方法发布的对象相同的程序集InsertNewUser

  3. 清单上的Users对象是否完整(例如,它是否有任何构造函数)?

  4. 您是否尝试过通过 fiddler 执行对端点的请求?通过这种方式,您可以排除客户端调用中的任何潜在错误,以查看控制器方法本身是否有效。

  5. 我注意到这一行:

    string lREST_Uri_Browse = string.Format(@"api/accountapi/saveuserdata"
    // User data
    /*pModelSerialized*/);
    

    您是否正在格式化 url 并将任何参数传递给它?如果是这样,参数是什么?您的 WebApi 路由是什么样的?

这应该足够开始了 - 让我知道你的进展情况。


顺便说一句:您的代码中有两件事让我印象深刻(与问题无关):

  • 让一个名为“Users”的类代表单个用户非常令人困惑。如果是您的代码,我建议将其更改为单数。

  • 对象上的属性Users使用缩写 - 我认为拼出它们并不那么昂贵,我可以向您保证,如果您输入全名而不是神秘的BCompanyID,或者不那么神秘但不那么神秘,那么任何新接触此代码的人都会感激不尽仍然难以阅读(并为此而写作)FName

于 2013-06-09T12:04:46.263 回答
1

几周前我遇到了同样的问题。在做了一些测试之后,我意识到我的 WebApi 应用程序默认使用的是 DataContractJsonSerializer,而不是 Newtonsoft。要修复它,您可以将服务器上的默认序列化程序更改为 NewtonSoft 或使用 DatacontractJsonSerializer 序列化您的对象并将其传递给 HttpWebRequest。

于 2016-11-17T16:14:52.017 回答
0

我会使用 jQuery 将一些 Json 发布到相同的 URL ( ),从而从等式中$.post(@"api/accountapi/saveuserdata", { Email: "e@example.com", FName = "Vlad" ... })消除。InsertNewUser如果你仍然得到一个空pNewUser参数,那么我会查看你的 API的SaveNewuser路由配置以确保服务器期望 SaveUserData(Users)如果您从 jQuery 获得非空值pNewUser,那么我会仔细查看InsertNewUser. 如果我必须下注,我会把钱花在路由配置上。

于 2013-06-09T14:45:17.100 回答
0

看来我的 LINQ 代码有错误

Users existingUser = asigCtx.Users.Where(u => u.Email == pNewUser.Email).SingleOrDefault();

在我解决这个问题后,请求就可以了。

Tnx 的帮助 :) 感谢。

于 2013-06-09T20:16:39.970 回答