通过 Azure 调度程序使用 post 将消息发送到 Azure 服务总线
send message to Azure service bus by Azure scheduler using post
我想通过 Azure 调度程序使用 post 将消息发送到 Azure 服务总线
喜欢这个页面中的演示
http://www.prasadthinks.com/
但我不知道如何在 Http Header.
中设置 'authorization' 属性
据我所知,'authorization' 属性 必须包含服务总线的访问令牌。
您可以使用共享访问策略的 key-name 和密钥通过代码生成访问令牌。
更多细节,您可以参考下面的代码。
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'属性,你可以复制it.But这个令牌有两个小时的限制。
Azure 调度程序作业设置如下:
此外,azure scheduler job已经支持将消息发送到服务总线,你不需要自己创建sas token,你可以在它的身份验证设置中添加keyName和key。
更多详情,您可以参考下图:
我想通过 Azure 调度程序使用 post 将消息发送到 Azure 服务总线 喜欢这个页面中的演示 http://www.prasadthinks.com/ 但我不知道如何在 Http Header.
中设置 'authorization' 属性据我所知,'authorization' 属性 必须包含服务总线的访问令牌。
您可以使用共享访问策略的 key-name 和密钥通过代码生成访问令牌。
更多细节,您可以参考下面的代码。
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'属性,你可以复制it.But这个令牌有两个小时的限制。
Azure 调度程序作业设置如下:
此外,azure scheduler job已经支持将消息发送到服务总线,你不需要自己创建sas token,你可以在它的身份验证设置中添加keyName和key。
更多详情,您可以参考下图: