Azure的新手,我在内部地址http://internal-server:182/api/policies上有一个内部Web API。我已经设置了Hybrid Connection internal-service.servicebus.windows.net。这已连接并且正在工作。
我的工作是使C#代码能够连接和检索数据。几天后,我查看了各种文章,视频等,它们似乎都比我尝试做的要先进,后者只是调用Web API并读取JSON。我试图简化代码,但收到错误:
401 MalformedToken: Invalid authorization header: The request is missing WRAP authorization credentials.
目前,我有以下代码:
using (var client = new HttpClient())
{
var url = "http://internal-service.servicebus.windows.net";
var tp = TokenProvider.CreateSharedAccessSignatureTokenProvider("RootManageSharedAccessKey", "<key goes here>");
var token = tp.GetWebTokenAsync(url, string.Empty, true, TimeSpan.FromHours(1))
.GetAwaiter()
.GetResult();
client.BaseAddress = new Uri(url);
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("ServiceBusAuthorization", token);
var response = client.GetAsync("/api/policies").Result;
string res = "";
using (HttpContent content = response.Content)
{
// ... Read the string.
Task<string> result = content.ReadAsStringAsync();
res = result.Result;
Label1.Text = res;
}
}
任何帮助或指导将不胜感激?此代码运行后,该Web应用将作为Azure Web App发布。
答案 0 :(得分:0)
您似乎没有发送正确的标头。
第一个建议:使用fiddler之类的代理拦截该呼叫,然后在对本地主机端口8888的呼叫中添加一个代理配置,之后,您可以尝试一些请求并查看发送到的原始http服务器上,您也可以对其进行修改直到其正常工作,一旦修改了代码,直到发送相同的原始http。
您可以在此处找到有关此信息的更多信息:
Microsoft Azure CreateQueue using Simple REST Client
https://github.com/ytechie/event-hubs-sas-generator