Web api在本地工作,但在部署到Azure时则不能

时间:2016-03-06 15:12:32

标签: c# ef-code-first entity-framework-6 asp.net-web-api2 azure-sql-database

我有一个我开发的Web Api,在本地运行时效果非常好,但是当我在Azure上发布它时,我得到了500 Internal Sever Error

我在数据库中有3个表 - “消息”,“用户”,“对话”

只有在我调用“对话”或“用户”时才会出现错误。 (对话包含用户和用户列表,其中包含对话列表。)

我不确定是什么导致这种情况,我不知道如何从此错误中获取更多信息。

我试过更改实体框架连接字符串,虽然我真的不知道我在做什么。我的web.config中的其他连接字符串似乎没问题。

这是数据库问题还是代码问题?

Web.confg:

<connectionStrings>
<add name="DefaultConnection" connectionString="Data Source=tcp:uqq5j22p7m.database.windows.net,1433;Initial Catalog=AA_db;Persist Security Info=True;User ID=KENH@uqq5j22p7m;Password=Password;Connect Timeout=30;Encrypt=True;MultipleActiveResultSets=True;"
  providerName="System.Data.SqlClient" />
<add name="AcademicAssistantContext" connectionString="Data Source=tcp:uqq5j22p7m.database.windows.net,1433;Initial Catalog=AA_db;Persist Security Info=True;User ID=KENH@uqq5j22p7m;Password=Password;Connect Timeout=30;Encrypt=True;MultipleActiveResultSets=True;" 
  providerName="System.Data.SqlClient" />

<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
  <parameters>
    <parameter value="Data Source=.; Integrated Security=True; MultipleActiveResultSets=True" />
  </parameters>
</defaultConnectionFactory>
<providers>
  <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>

2 个答案:

答案 0 :(得分:3)

如果没有调试,很难说出错误是什么。

您可以使用log4net或sirilog等任何记录器,然后在返回HTTP 500的操作或方法中记录错误,或者live debug your code in azure

此外,如果所有Web API应用程序都没有运行(返回内部服务器错误),那么它似乎是一个配置错误(例如,错误的ConnectionString),但如果您的某些操作返回200而其他操作返回500,那么您应该调试你的代码或记录你的错误,以了解它的确切异常。

答案 1 :(得分:0)

我刚刚找到了解决方案! 我在做:

public IQueryable<Conversation> GetConversations()
{
    return db.Conversations;
}

这一定是导致序列化问题,因为它在更改为:

时有效
public IEnumerable<Conversation> GetConversations()
{
    return db.Conversations.ToList();
}

几天浪费在如此小的事情上!