.net 创建Azure IoT中心设备
是否可以使用.NET在Azure IoT Hub上以编程方式创建新设备?使用microsoft.docs上的所有教程,通过Azure Portal或Azure CLI创建设备 如果有的话,你能提供一些有趣的链接吗?提前感谢您。有一个教程供您学习 相关的API是注册表管理器.AddDeviceAsync.net 创建Azure IoT中心设备,.net,azure,iot,azure-iot-hub,.net,Azure,Iot,Azure Iot Hub,是否可以使用.NET在Azure IoT Hub上以编程方式创建新设备?使用microsoft.docs上的所有教程,通过Azure Portal或Azure CLI创建设备 如果有的话,你能提供一些有趣的链接吗?提前感谢您。有一个教程供您学习 相关的API是注册表管理器.AddDeviceAsync RegistryManager manager = RegistryManager.CreateFromConnectionString(connectionString); a
RegistryManager manager = RegistryManager.CreateFromConnectionString(connectionString);
await manager.AddDeviceAsync(new Device(deviceID));
您可以在GitHub上的Azure IoT SDK C#repo上找到。有一个教程供您学习
相关的API是注册表管理器.AddDeviceAsync
RegistryManager manager = RegistryManager.CreateFromConnectionString(connectionString);
await manager.AddDeviceAsync(new Device(deviceID));
您可以在GitHub上的Azure IoT SDK C#repo上找到。此外,您还可以使用
- 以下是该计划的实施情况:
字符串连接字符串=”; 字符串设备ID=“”; 字符串IoTubName=SharedAccessSignatureBuilder.GetHostNameNamespaceFromConnectionString(connectionString); 字符串sasToken=SharedAccessSignatureBuilder.GetSASTokenFromConnectionString(connectionString); string requestUri=$“https://{iothubName}.azure devices.net/devices/{deviceId}?api version=2018-06-30”; var httpclient=新的httpclient(); httpclient.DefaultRequestHeaders.Add(“授权”,sasToken); var hrm=httpclient.PutAsJsonAsync(requestUri,new{deviceId=deviceId}); hrm.EnsureSuccessStatusCode(); 字符串响应=hrm.Content.ReadAsStringAsync().Result;
public sealed class SharedAccessSignatureBuilder
{
public static string GetHostNameNamespaceFromConnectionString(string connectionString)
{
return GetPartsFromConnectionString(connectionString)["HostName"].Split('.').FirstOrDefault();
}
public static string GetSASTokenFromConnectionString(string connectionString, uint hours = 24)
{
var parts = GetPartsFromConnectionString(connectionString);
return GetSASToken(parts["HostName"], parts["SharedAccessKey"], parts["SharedAccessKeyName"], hours);
}
public static string GetSASToken(string resourceUri, string key, string keyName = null, uint hours = 24)
{
var expiry = GetExpiry(hours);
string stringToSign = System.Web.HttpUtility.UrlEncode(resourceUri) + "\n" + expiry;
HMACSHA256 hmac = new HMACSHA256(Convert.FromBase64String(key));
var signature = Convert.ToBase64String(hmac.ComputeHash(Encoding.UTF8.GetBytes(stringToSign)));
var sasToken = String.Format(CultureInfo.InvariantCulture, "SharedAccessSignature sr={0}&sig={1}&se={2}", HttpUtility.UrlEncode(resourceUri), HttpUtility.UrlEncode(signature), expiry);
if(!string.IsNullOrEmpty(keyName))
sasToken += String.Format(CultureInfo.InvariantCulture, "&skn={0}", keyName);
return sasToken;
}
private static Dictionary<string, string> GetPartsFromConnectionString(string connectionString)
{
return connectionString.Split(new[] { ';' }, StringSplitOptions.RemoveEmptyEntries).Select(s => s.Split(new[] { '=' }, 2)).ToDictionary(x => x[0].Trim(), x => x[1].Trim());
}
// default expiring = 24 hours
private static string GetExpiry(uint hours = 24)
{
TimeSpan sinceEpoch = DateTime.UtcNow - new DateTime(1970, 1, 1);
return Convert.ToString((int)sinceEpoch.TotalSeconds + 3600 * hours);
}
}
公共密封类SharedAccessSignatureBuilder
{
公共静态字符串GetHostNameNamespaceFromConnectionString(字符串connectionString)
{
返回GetPartsFromConnectionString(connectionString)[“主机名”].Split('.').FirstOrDefault();
}
公共静态字符串GetSASTokenFromConnectionString(字符串connectionString,uint小时=24)
{
var parts=GetPartsFromConnectionString(connectionString);
返回GetSASToken(部件[“主机名”]、部件[“SharedAccessKey”]、部件[“SharedAccessKeyName”]、小时数);
}
公共静态字符串GetSASToken(字符串资源URI,字符串键,字符串键名=null,uint小时数=24)
{
var到期=GetExpiry(小时);
字符串stringToSign=System.Web.HttpUtility.UrlEncode(resourceUri)+“\n”+到期日;
HMACSHA256 hmac=新的HMACSHA256(Convert.FromBase64String(key));
var signature=Convert.ToBase64String(hmac.ComputeHash(Encoding.UTF8.GetBytes(stringToSign));
var sasToken=String.Format(CultureInfo.InvariantCulture,“SharedAccessSignature sr={0}&sig={1}&se={2}”、HttpUtility.UrlEncode(resourceUri)、HttpUtility.UrlEncode(签名)、到期);
如果(!string.IsNullOrEmpty(keyName))
sasToken+=String.Format(CultureInfo.InvariantCulture,“&skn={0}”,关键字名);
返回令牌;
}
私有静态字典GetPartsFromConnectionString(string connectionString)
{
返回connectionString.Split(新[]{';'},StringSplitOptions.RemoveEmptyEntries)。选择(s=>s.Split(新[]{'='},2)).ToDictionary(x=>x[0].Trim(),x=>x[1].Trim());
}
//默认到期时间=24小时
私有静态字符串GetExpiry(uint小时=24)
{
TimeSpan-sinceEpoch=DateTime.UtcNow-新日期时间(1970,1,1);
返回Convert.ToString((int)sinceEpoch.TotalSeconds+3600*小时);
}
}
此外,您还可以使用
- 以下是该计划的实施情况:
字符串连接字符串=”; 字符串设备ID=“”; 字符串IoTubName=SharedAccessSignatureBuilder.GetHostNameNamespaceFromConnectionString(connectionString); 字符串sasToken=SharedAccessSignatureBuilder.GetSASTokenFromConnectionString(connectionString); string requestUri=$“https://{iothubName}.azure devices.net/devices/{deviceId}?api version=2018-06-30”; var httpclient=新的httpclient(); httpclient.DefaultRequestHeaders.Add(“授权”,sasToken); var hrm=httpclient.PutAsJsonAsync(requestUri,new{deviceId=deviceId}); hrm.EnsureSuccessStatusCode(); 字符串响应=hrm.Content.ReadAsStringAsync().Result;
public sealed class SharedAccessSignatureBuilder
{
public static string GetHostNameNamespaceFromConnectionString(string connectionString)
{
return GetPartsFromConnectionString(connectionString)["HostName"].Split('.').FirstOrDefault();
}
public static string GetSASTokenFromConnectionString(string connectionString, uint hours = 24)
{
var parts = GetPartsFromConnectionString(connectionString);
return GetSASToken(parts["HostName"], parts["SharedAccessKey"], parts["SharedAccessKeyName"], hours);
}
public static string GetSASToken(string resourceUri, string key, string keyName = null, uint hours = 24)
{
var expiry = GetExpiry(hours);
string stringToSign = System.Web.HttpUtility.UrlEncode(resourceUri) + "\n" + expiry;
HMACSHA256 hmac = new HMACSHA256(Convert.FromBase64String(key));
var signature = Convert.ToBase64String(hmac.ComputeHash(Encoding.UTF8.GetBytes(stringToSign)));
var sasToken = String.Format(CultureInfo.InvariantCulture, "SharedAccessSignature sr={0}&sig={1}&se={2}", HttpUtility.UrlEncode(resourceUri), HttpUtility.UrlEncode(signature), expiry);
if(!string.IsNullOrEmpty(keyName))
sasToken += String.Format(CultureInfo.InvariantCulture, "&skn={0}", keyName);
return sasToken;
}
private static Dictionary<string, string> GetPartsFromConnectionString(string connectionString)
{
return connectionString.Split(new[] { ';' }, StringSplitOptions.RemoveEmptyEntries).Select(s => s.Split(new[] { '=' }, 2)).ToDictionary(x => x[0].Trim(), x => x[1].Trim());
}
// default expiring = 24 hours
private static string GetExpiry(uint hours = 24)
{
TimeSpan sinceEpoch = DateTime.UtcNow - new DateTime(1970, 1, 1);
return Convert.ToString((int)sinceEpoch.TotalSeconds + 3600 * hours);
}
}
公共密封类SharedAccessSignatureBuilder
{
公共静态字符串GetHostNameNamespaceFromConnectionString(字符串connectionString)
{
返回GetPartsFromConnectionString(connectionString)[“主机名”].Split('.').FirstOrDefault();
}
公共静态字符串GetSASTokenFromConnectionString(字符串connectionString,uint小时=24)
{
var parts=GetPartsFromConnectionString(connectionString);
返回GetSASToken(部件[“主机名”]、部件[“SharedAccessKey”]、部件[“SharedAccessKeyName”]、小时数);
}
公共静态字符串GetSASToken(字符串资源URI,字符串键,字符串键名=null,uint小时数=24)
{
var到期=GetExpiry(小时);
字符串stringToSign=System.Web.HttpUtility.UrlEncode(resourceUri)+“\n”+到期日;
HMACSHA256 hmac=新的HMACSHA256(Convert.FromBase64String(key));
var signature=Convert.ToBase64String(hmac.ComputeHash(Encoding.UTF8.GetBytes(stringToSign));
var sasToken=String.Format(CultureInfo.InvariantCulture,“SharedAccessSignature sr={0}&sig={1}&se={2}”、HttpUtility.UrlEncode(resourceUri)、HttpUtility.UrlEncode(签名)、到期);
如果(!string.IsNullOrEmpty(keyName))
sasToken+=String.Format(CultureInfo.InvariantCulture,“&skn={0}”,关键字名);
返回令牌;
}
私有静态字典GetPartsFromConnectionString(string connectionString)
{
返回connectionString.Split(新[]{';'},StringSplitOptions.RemoveEmptyEntries)。选择(s=>s.Split(新[]{'='},2)).ToDictionary(x=>x[0].Trim(),x=>x[1].Trim());
}
//默认到期时间=24小时
私有静态字符串GetExpiry(uint小时=24)
{
TimeSpa