Отправить сообщение в служебную шину Azure с помощью планировщика Azure, используя сообщение
Я хочу отправить сообщение в служебную шину Azure с помощью планировщика Azure, используя публикацию, подобную демонстрации на этой странице http://www.prasadthinks.com/ но я не знаю, как установить свойство авторизации в заголовке Http.
1 ответ
Насколько я знаю, свойство 'authorization' должно содержать токен доступа служебной шины.
Вы можете использовать ключ и имя вашей политики общего доступа для генерации токена доступа с помощью кодов.
Более подробно, вы можете обратиться к ниже кодов.
string keyName = "keyname";
string key = "key";
var sasToken = createToken("http://yourservicebusname.servicebus.windows.net/queuename", keyName, key);
функция createToken:
private static string createToken(string resourceUri, string keyName, string key)
{
TimeSpan sinceEpoch = DateTime.UtcNow - new DateTime(1970, 1, 1);
var expiry = Convert.ToString((int)sinceEpoch.TotalSeconds + 7200); //EXPIRES in 2h
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)));
//this is the auth token
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;
}
Результат как ниже:
Это свойство 'authorization', вы можете скопировать его. Но этот токен имеет ограничение в два часа.
Настройка задания планировщика Azure, как показано ниже:
Кроме того, задание планировщика Azure уже поддерживает отправку сообщения на служебную шину, вам не нужно создавать токен sas самостоятельно, вы можете просто добавить keyName и ввести ключ в его настройках аутентификации.
Более подробно, вы можете обратиться к изображениям ниже: