歡迎光臨
每天分享高質量文章

Docker最全教程之使用.NET Core推送釘釘訊息(二十)

前言

上一篇我們透過實戰分享了使用Go推送釘釘訊息,由於技癢,筆者現在也編寫了一個.NET Core的Demo,作為簡單的對照和說明。

最後,由於精力有限,筆者希望有興趣的朋友可以分享下使用CoreRT將.NET Core編譯成機器程式碼這塊的實踐。

 

目錄

 

  • 使用.NET Core推送釘釘訊息
  • 獲取引數
  • 設定訊息資料格式
  • 傳送請求
  • 設定Dockerfile
  • 執行並設定環境變數推送訊息

 

使用.NET Core推送釘釘訊息

這裡我們使用.NET Core來完成相關需求,註意,這裡是.NET Core,而不是ASP.NET Core。需求和上面類似,工程相關依賴如下所示:

    Include=“Microsoft.Extensions.Configuration”Version=“2.2.0”/>

    Include=“Microsoft.Extensions.Configuration.CommandLine”Version=“2.2.0”/>

    Include=“Microsoft.Extensions.Configuration.EnvironmentVariables”Version=“2.2.0”/>

    Include=“Microsoft.Extensions.Http”Version=“2.2.0”/>

    Include=“Newtonsoft.Json”Version=“12.0.1”/>

 

以下是相關的主體程式碼:

 

獲取引數

 

從環境變數或者命令列引數獲取配置:

       ///

       ///環境變數串列

       ///

       privatestaticreadonlystring[] EnvList =

       {

            //釘釘機器人地址

            “WEBHOOK”,

            //@的手機號碼

            “AT_MOBILES”,

            //@所有人

            “IS_AT_ALL”,

           //訊息內容

            “MESSAGE”,

            //訊息型別(僅支援文字和markdown)

            “MSG_TYPE”

       };

 

       privatestaticvoid Main(string[] args)

       {

            var config = newConfigurationBuilder()

                        //支援命令列引數

                        .AddCommandLine(args)

                        //支援環境變數

                       .AddEnvironmentVariables()

                        .Build();

            #region引數檢查

            foreach (var envName in EnvList)

            {

                var value =config[envName];

                if (string.IsNullOrWhiteSpace(value)&& envName != “AT_MOBILES” && envName != “IS_AT_ALL”)

                {

                    Console.WriteLine($”{envName}不能為空!”);

                    return;

                }

            }

            if (string.IsNullOrWhiteSpace(config[“AT_MOBILES”]) && string.IsNullOrWhiteSpace(config[“IS_AT_ALL”]))

            {

                Console.WriteLine(“必須設定引數 AT_MOBILES 和 IS_AT_ALL 兩者之一!”);

                return;

            }

            #endregion

            try

            {

                //推送訊息

               SetDataAndSendWebhooks(config).Wait();

            }

            catch (Exception ex)

           {

               Console.WriteLine(ex.ToString());

            }

       }

 

設定訊息資料格式

設定訊息格式,為了簡單,這裡我們使用匿名類:

       ///

       ///設定訊息並呼叫Webhook

       ///

       ///config“>

       ///

       privatestaticasync Task SetDataAndSendWebhooks(IConfigurationRoot config)

       {

            var at = new

            {

                AtMobiles = config[“AT_MOBILES”]?.Split(‘,’),

                IsAtAll = Convert.ToBoolean(config[“IS_AT_ALL”] ?? “false”)

            };

            switch (config[“MSG_TYPE”])

            {

                case“text”:

                    {

                        var data = new

                        {

                            Msgtype = “text”,

                            Text = new

                            {

                                Content =config[“MESSAGE”]

                            },

                            At = at

                        };

                        awaitSendWebhooks(config[“WEBHOOK”], data);

                        break;

                    }

                case“markdown”:

                    {

                        var data = new

                        {

                            Msgtype = “markdown”,

                            Markdown = new

                            {

                                Title = “釘釘通知”,

                                Text = config[“MESSAGE”]

                            },

                            At = at

                        };

                        awaitSendWebhooks(config[“WEBHOOK”], data);

                        break;

                    }

                default:

                    {

                        Console.WriteLine($”不支援的格式:{config[“MSG_TYPE”]});

                        break;

                    }

            }

       }

 

傳送請求

此處程式碼使用Newtonsoft.JsonJSON序列化,然後使用Microsoft.Extensions.HttpHttpClient庫來傳送Post請求。

在資料格式這塊,我們透過配置做了以下設定:

  • 忽略Null值。也就是為null的屬性不做JSON序列化。
  • 設定屬性命名規則為Camel-Case駝峰式命名法,首字母小寫。

 

主體程式碼如下所示:

       ///

       ///呼叫webhook

       ///

       ///

贊(0)

分享創造快樂