Docker最全教程之使用.NET Core推送钉钉消息(十九)
前言
上一篇我们通过实战分享了使用Go推送钉钉消息,由于技痒,笔者现在也编写了一个.NET Core的Demo,作为简单的对照和说明。
最后,由于精力有限,笔者希望有兴趣的朋友可以分享下使用CoreRT将.NET Core编译成机器代码这块的实践。
目录
使用.NET Core推送钉钉消息
获取参数
设置消息数据格式
发送请求
设置Dockerfile
运行并设置环境变量推送消息
使用.NET Core推送钉钉消息
这里我们使用.NET Core来完成相关需求,注意,这里是.NET Core,而不是ASP.NET Core。需求和上面类似,工程相关依赖如下所示:
<PackageReferenceInclude="Microsoft.Extensions.Configuration"Version="2.2.0"/> <PackageReferenceInclude="Microsoft.Extensions.Configuration.CommandLine"Version="2.2.0"/> <PackageReferenceInclude="Microsoft.Extensions.Configuration.EnvironmentVariables"Version="2.2.0"/> <PackageReferenceInclude="Microsoft.Extensions.Http"Version="2.2.0"/> <PackageReferenceInclude="Newtonsoft.Json"Version="12.0.1"/>
以下是相关的主体代码:
获取参数
从环境变量或者命令行参数获取配置:
///<summary> ///环境变量列表 ///</summary> 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()); } }
设置消息数据格式
设置消息格式,为了简单,这里我们使用匿名类:
///<summary> ///设置消息并调用Webhook ///</summary> ///<param name="config"></param> ///<returns></returns> 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.Json做JSON序列化,然后使用Microsoft.Extensions.Http的HttpClient库来发送Post请求。
在数据格式这块,我们通过配置做了以下设置:
忽略Null值。也就是为null的属性不做JSON序列化。
设置属性命名规则为Camel-Case驼峰式命名法,首字母小写。
主体代码如下所示:
///<summary> ///调用webhook ///</summary> ///<typeparamname="T"></typeparam> ///<param name="url">webhook地址</param> ///<param name="data">消息</param> ///<returns></returns> privatestaticasync Task SendWebhooks<T>(string url, T data) where T : class { JsonConvert.DefaultSettings = newFunc<JsonSerializerSettings>(() =>newJsonSerializerSettings() { NullValueHandling =NullValueHandling.Ignore, ContractResolver = newCamelCasePropertyNamesContractResolver() }); var jsonData =JsonConvert.SerializeObject(data); Console.WriteLine(jsonData); using (var httpClient = new HttpClient()) { var content = newStringContent(jsonData); content.Headers.ContentType = newMediaTypeHeaderValue("application/json"); var result = awaithttpClient.PostAsync(url, content); result.EnsureSuccessStatusCode(); Console.WriteLine($"Send webhook succeed. StatusCode:{result.StatusCode}"); } }
设置Dockerfile
在之前我们已经讲述过,使用了分阶段构建。整个Dockerfile基本上使用VS Docker tool生成:
FROMmicrosoft/dotnet:2.2-runtime AS base WORKDIR /app FROMmicrosoft/dotnet:2.2-sdk AS build WORKDIR /src COPY DingTalk.NET/DingTalk.NET.csprojDingTalk.NET/ RUN dotnet restoreDingTalk.NET/DingTalk.NET.csproj COPY . . WORKDIR /src/DingTalk.NET RUN dotnet buildDingTalk.NET.csproj -c Release -o /app FROM build AS publish RUN dotnet publish DingTalk.NET.csproj-c Release -o /app FROM base AS final WORKDIR /app COPY --from=publish/app . ENTRYPOINT ["dotnet", "DingTalk.NET.dll"] # 注意不要单独使用 MAINTAINER 指令,MAINTAINER已被Label标签代替 LABEL MAINTAINER ="xinlai@xin-lai.com" # LABEL指令用于将元数据添加到镜像,支持键值对和JSON,我们可以使用 docker inspect 命令来查看 LABELDingtalkComponent='{\ "description": "使用钉钉发送通知消息.",\ "input": [\ {"name": "WEBHOOK","desc": "必填, 钉钉机器人Webhook地址"},\ {"name":"AT_MOBILES", "desc": "非必填,被@人的手机号"},\ {"name":"IS_AT_ALL", "desc": "非必填,@所有人时:true, 否则为:false"},\ {"name": "MESSAGE","desc": "必填,自定义发送的消息内容"},\ {"name":"MSG_TYPE", "desc": "必填,自定义发送的消息类型,目前仅支持text和markdown"}\ ]\ }'
编译完成后,我们来查看下镜像大小:
注意:
通过上图我们可以看到,镜像大小不到200M,相比GO体重大了许多,但是相比其他语言却轻了不少。不过,我们可以通过官方开源库CoreRT将.NET Core编译成机器代码,也就是.NET Core也可以做到编译完成后只有几M大小。有兴趣的朋友可以分享下这块的实践。
运行并设置环境变量推送消息
我们使用PowerShell编写简单脚本如下所示:
docker build --rm-f "Dockerfile" -t dingtalk.net:latest . docker run --rm -e"WEBHOOK=https://oapi.dingtalk.com/robot/send?access_token={yourAccess Token}" ` -e "MESSAGE=*使用.NET Core发送钉钉消息。*" ` -e "IS_AT_ALL=true" ` -e "MSG_TYPE=markdown" ` -d dingtalk.net
效果如图:
Docker最全教程之使用.NET Core推送钉钉消息(十九)的更多相关文章
- Docker最全教程之使用Node.js搭建团队技术文档站(二十三)
前言 各种编程语言均有其优势和生态,有兴趣的朋友完全可以涉猎多门语言.在平常的工作之中,也可以尝试选择相对适合的编程语言来完成相关的工作. 在团队技术文档站搭建这块,笔者尝试了许多框架,最终还是选择了 ...
- Docker最全教程——从理论到实战(八)
在本系列教程中,笔者希望将必要的知识点围绕理论.流程(工作流程).方法.实践来进行讲解,而不是单纯的为讲解知识点而进行讲解.也就是说,笔者希望能够让大家将理论.知识.思想和指导应用到工作的实际场景和实 ...
- Docker最全教程之使用Tencent Hub来完成CI(九)
使用Tencent Hub来完成CI 关于Tencent Hub Tencent Hub是腾讯出品的DevOps服务.主要提供多存储格式的版本管理,支持Docker Image.Binary.Helm ...
- Docker最全教程——从理论到实战(七)
在本系列教程中,笔者希望将必要的知识点围绕理论.流程(工作流程).方法.实践来进行讲解,而不是单纯的为讲解知识点而进行讲解.也就是说,笔者希望能够让大家将理论.知识.思想和指导应用到工作的实际场景和实 ...
- Docker最全教程——从理论到实战(六)
托管到腾讯云容器服务 托管到腾讯云容器服务,我们的公众号“magiccodes”已经发布了相关的录屏教程,大家可以结合本篇教程一起查阅. 自建还是托管? 在开始之前,我们先来讨论一个问题——是自建 ...
- Docker最全教程——从理论到实战(五)
往期内容链接 Docker最全教程——从理论到实战(一) Docker最全教程——从理论到实战(二) Docker最全教程——从理论到实战(三) Docker最全教程——从理论到实战(四) 本篇教程持 ...
- Docker最全教程——从理论到实战
Docker最全教程——从理论到实战(一) Docker最全教程——从理论到实战(二) Docker最全教程——从理论到实战(三) Docker最全教程——从理论到实战(四) Docker最全教程—— ...
- Docker最全教程
摘自雪雁大佬的博客,地址:https://www.cnblogs.com/codelove/default.html 目录: Docker最全教程——从理论到实战(一) Docker最全教程——从理论 ...
- Docker最全教程——从理论到实战(十七)
前言 上一篇我们通过实战分享了使用Go推送钉钉消息,由于技痒,笔者现在也编写了一个.NET Core的Demo,作为简单的对照和说明. 最后,由于精力有限,笔者希望有兴趣的朋友可以分享下使用CoreR ...
随机推荐
- 30岁天才上班族利用Python人脸监控BOSS,伪装成认真上班的样子!
如今Python程序员可以做深度学习算法实现人脸识别,得益于国外开源框架,虽然它不能达到face++和众多人脸识别公司,但实际应用并没有受到太大的压力.下图为tensorflow的5点定位加情感测试. ...
- android sqlite no such table
今天在学习android SQLite出现android sqlite no such table错误提示,提示的意思我没有创建我要插入的表,网上也没有搜索一下,也尝试了,发现还是没有解决到我的问题, ...
- Spring Boot 快速入门笔记
Spirng boot笔记 简介 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发 ...
- Git的一些操作
前言 记录一些经常需要用到的命令. 私钥.公钥的生成(默认在C盘用户文件下生成) ssh-keygen -t rsa //rsa加密 拉取远程分支并与本地分支合并 git pull [url] 上述效 ...
- sql中having、group by用法及常用聚合函数
having是用在聚合函数的用法.当我们在用聚合函数的时候,一般都要用到GROUP BY 先进行分组,然后再进行聚合函数的运算.运算完后就要用到HAVING 的用法了,就是进行判断了. 注意:sele ...
- REST风格框架实战:从MVC到前后端分离(附完整Demo)
既然MVC模式这么好,难道它就没有不足的地方吗?我认为MVC至少有以下三点不足:(1)每次请求必须经过“控制器->模型->视图”这个流程,用户才能看到最终的展现的界面,这个过程似乎有些复杂 ...
- Spring Cloud authentication with JWT service
@RequestMapping(value = "/authenticate", method = RequestMethod.POST) public ResponseEntit ...
- nodejs模板加载的问题
JADE模板:http://jumplink.github.io/jade2html2jade/ HTML转JADE,跟imooc上一步步来就搞定了 直接加载HTML静态资源: var express ...
- java 基础之 反射技术
1. java代码 在 java 语言中最核心的就是代码的运行, 按照面向对象的思想,在调用java代码时往往需要先创建对象,再调用方法, 而写在方法中的即所谓的java 代码 一段java代码在程序 ...
- RabbitMQ (二)工作队列
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/37620057 本系列教程主要来自于官网入门教程的翻译,然后自己进行了部分的修改与 ...