我有一个非常简单的测试应用程序,它创建一个 WebClient 并从第三方 API 获得响应(敏感信息已删除):
using (WebClient client = new WebClient())
{
var baseAddress = new Uri("https://test-url");
client.Headers["Content-Type"] = "application/json";
var parms = Encoding.Default.GetBytes(
"{ \"username\":\"<USERNAME>\"," +
"\"password\":\<PASSWORD>\"," +
"\"client_id\":\"<CLIENT_ID>\"," +
"\"client_secret\":\"<CLIENT_SECRET>\"" +
"}"
);
// Get access token
var responseObject = new ResponseObject();
var responseBytes = new byte[] { };
string responseBody;
try
{
responseBytes = client.UploadData(baseAddress, "POST", parms);
responseBody = Encoding.UTF8.GetString(responseBytes);
responseObject = JsonConvert.DeserializeObject<ResponseObject>(responseBody);
}
catch (WebException ex)
{
var resp = (HttpWebResponse)ex.Response;
Console.WriteLine(resp.StatusDescription);
}
}
当我在本地多次运行此代码时,它可以完美运行。我得到回复,我可以从中提取我需要的信息。
但是,一旦我将此代码部署到 Azure,我尝试使用 POSTMAN 调用 API,并收到错误消息,告诉我“对象引用未设置为对象的实例”。try/catch 中这一行的错误:
var resp = (HttpWebResponse)ex.Response;
因此,我在 API 上附加了一个远程调试器,并逐步完成了这一小段代码。对我来说奇怪的是,当程序跳转到catch代码部分时我可以看到正确的内容,但是没有exException 对象。我的意思是我可以ex在调试中将鼠标悬停在变量上并且什么都没有出现。即使悬停在ex.Response上面也没有显示任何内容。因此,由于那里什么都没有(即ex似乎不存在,甚至没有null值),应用程序会因空引用错误而爆炸。
我的想法是 Azure 中的某些东西可能会阻止 URL,因为我可以在本地运行它而不会出现问题。我在这里询问了我们的网络人员,他们说不应该设置任何他们知道的限制来阻止呼叫出去。奇怪的是,我在 Azure 中为此应用程序打开了诊断日志记录,但没有显示任何内容。即使我可以使用浏览器或 PostMan 访问该应用程序,日志中也没有出现任何内容。所以,这又是一件奇怪的事情。我希望能够看到一些东西。
无论如何,我希望也许有人以前遇到过类似的事情,并且可以将我指向一篇文章/解决方案/博客,这可能会阐明这一点并让我找到一个可行的解决方案。
谢谢!
编辑:添加了错误消息的屏幕截图,因为它出现在浏览器中:
编辑:添加了应用程序引发以下异常的行:
responseBytes = client.UploadData(baseAddress, "POST", parms);
尝试执行此行后立即跳转到catch,但没有出现 WebException。
编辑:我找到了解决方案并将其添加为下面的答案。

