ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

c# – Web api在本地工作,但在部署到Azure时则不行

2019-06-28 05:03:25  阅读:293  来源: 互联网

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


我有一个我开发的Web Api,它在本地运行时工作得非常好,但是当我在Azure上发布它时,我得到500内部服务器错误.

我在数据库中有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>

解决方法:

没有调试就很难说出错误是什么.

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

此外,如果整个Web API应用程序没有运行(返回内部服务器错误),它似乎是一个配置错误(例如,错误的ConnectionString),但如果您的某些操作返回200而其他操作返回500,您应该调试您的代码或日志你的错误,知道确切的例外.

标签:c,ef-code-first,entity-framework-6,asp-net-web-api2,azure-sql-database
来源: https://codeday.me/bug/20190628/1312440.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有