Azure Service Bus Restful Api获取

我正在尝试使用SAS生成访问Azure Service Bus Resftul API。我的理解是,我需要生成一个authorization标头,其内容如下:-

SharedaccessSignature sig=<sig>&
se=<epochexpirydate>&skn=RootManageSharedaccessKey&
sr=<urlToQueue>

我尝试使用邮递员向https://service-bus-namespace.servicebus.windows.net/queuename发送请求

我使用通过在线sha256生成器加密为SHA256的sr\nepoch-time中的URL生成SAS的签名。

但是我总是得到401 SubCode:40103无效的授权令牌签名。希望有人可以给我帮助,以便我可以从队列中获取消息。

示例:

SharedaccessSignature sig=ab5c0a1b42b96af5ef9cbc85c7088651e9ebf8785d1eeffe6c4955be2c70ca2b&se=7270650090&skn=MyaccessKey&sr=https%3A%2F%2Fnamespace.servicebus.windows.net%2Fqueuename

iCMS 回答:Azure Service Bus Restful Api获取

根据401错误,表示令牌无效。

使用以下代码生成正确的SAS令牌,然后将生成的令牌传递给 Authorization 标头:

using System;
using System.Globalization;
using System.Security.Cryptography;
using System.Text;
using System.Web;

namespace App1
{
    class Program
    {
        static readonly string queueUrl = "TODO"; // Format: "https://<service bus namespace>.servicebus.windows.net/<queue name>";
        static readonly string signatureKeyName = "TODO";
        static readonly string signatureKey = "TODO";
        static readonly TimeSpan timeToLive = TimeSpan.FromDays(1);
        static void Main(string[] args)
        {
            var token = GetSasToken(queueUrl,signatureKeyName,signatureKey,timeToLive);
            Console.WriteLine("Authorization: " + token);
            Console.WriteLine("Press any key to exit.");
            Console.ReadLine();
        }
        public static string GetSasToken(string resourceUri,string keyName,string key,TimeSpan ttl)
        {
            var expiry = GetExpiry(ttl);
            string stringToSign = HttpUtility.UrlEncode(resourceUri) + "\n" + expiry;
            HMACSHA256 hmac = new HMACSHA256(Encoding.UTF8.GetBytes(key));
            var signature = Convert.ToBase64String(hmac.ComputeHash(Encoding.UTF8.GetBytes(stringToSign)));
            var sasToken = String.Format(CultureInfo.InvariantCulture,"SharedAccessSignature sr={0}&sig={1}&se={2}&skn={3}",HttpUtility.UrlEncode(resourceUri),HttpUtility.UrlEncode(signature),expiry,keyName);
            return sasToken;
        }

        private static string GetExpiry(TimeSpan ttl)
        {
            TimeSpan expirySinceEpoch = DateTime.UtcNow - new DateTime(1970,1,1) + ttl;
            return Convert.ToString((int)expirySinceEpoch.TotalSeconds);
        }
    }
}
本文链接:https://www.f2er.com/2273692.html

大家都在问