根據阿里雲物聯網普通的定義,事件上報有 信息、告警、故障三種類型,事件是設備上傳的消息通知,應當及時處理。html
打開阿里雲物聯網控制檯,進入產品,點擊 自定義功能 ,添加一個事件。
node
CZGL.AliIoTClient 中,有四個上傳事件的方法git
public int Thing_Event_Post(string eventName, string content, [bool isToLower = True]) public int Thing_Event_Post(string eventName, string content, [bool isToLower = True], [System.Text.Encoding encoding = null]) public int Thing_Event_Post<TModel>(TModel model, string eventName, [bool isToLower = True]) public int Thing_Event_Post<TModel>(TModel model, string eventName, [bool isToLower = True], [System.Text.Encoding encoding = null])
eventName: 事件的名稱,即標識符。
content: Alink json 內容 isToLower:是否轉爲小寫 encoding: 自定義上傳 Alink json 的編碼 model: 事件的模型json
第一種方法須要手動編寫好 json,而後經過方法上傳。 第二種方法在第一種方法的基礎上容許自定義字符編碼。 第三種、第四種是傳入模型,由 CZGL.AliIoTClient 處理好再上傳。post
每次只能上傳一個事件,一個事件對應一個 模型 或 Alink json。
在 CZGL.AliIoTClient 中,你每次上傳一個事件時,都須要設置此事件的名稱。阿里雲
根據上面在阿里雲物聯網控制檯定義的事件,編寫模型。
預覽要生成的 Alink json :編碼
{
"id": "123", "version": "1.0", "params": { "value": { "temperature":100.1 }, "time": 1524448722000 }, "method": "thing.event.cpuerror.post" }
對應模型以下:spa
public class Cpuerror { public Cpuerror() { @params = new Params(); } public string id { get { return DateTime.Now.Ticks.ToString(); } set { } } public string version { get { return "1.0"; } set { } } public Params @params { get; set; } public class Params { public Params() { value = new Value(); } public Value value { get; set; } public long time { get { return AliIoTClientJson.GetUnixTime(); } set { } } public class Value { public float temperature { get; set; } } } public string @method { get { return "thing.event.cpuerror.post"; } set { } } }
一個事件對應一個類,若是事件裏有多個輸出參數,則在 Value 裏定義好。code
{
...
...
public class Value { public float temperature { get; set; } /* *定義多個輸出參數 */ } ... ... }
上報事件:htm
Cpuerror cpuerror = new Cpuerror(); cpuerror.@params.value.temperature = 100.1F; client.Thing_Event_Post<Cpuerror>(cpuerror, "cpuerror", false);
4)容錯 上傳事件的 Alink json 能夠 容錯
,這給咱們編寫代碼時帶來了方便。、
例如將上面上傳事件的代碼改一下:
public class Cpuerror { public string name = "cpuerror"; public Cpuerror() { @params = new Params(); } public string id { get { return DateTime.Now.Ticks.ToString(); } set { } } public string version { get { return "1.0"; } set { } } public Params @params { get; set; } public class Params { public Params() { value = new Value(); } public Value value { get; set; } public long time { get { return AliIoTClientJson.GetUnixTime(); } set { } } public class Value { public float temperature { get; set; } } } public string @method { get { return $"thing.event.{name}.post"; } set { } } }
Cpuerror cpuerror = new Cpuerror(); cpuerror.@params.value.temperature = 100.2F; client.Thing_Event_Post<Cpuerror>(cpuerror, cpuerror.name, false);
對於 消息ID 等是必不可少的,「可多不可少」,其它無關字段能夠增長上去,不會影響到上傳和使用,例如上面的例子增長了一個 name 屬性。