nodejs通過(guò)釘釘群機(jī)器人推送消息的實(shí)現(xiàn)代碼
Intro
最近在用 nodejs 寫爬蟲(chóng),之前的 nodejs 爬蟲(chóng)代碼用 js 寫的,感覺(jué)可維護(hù)性太差,也沒(méi)有智能提示,于是把js改用ts(typescript)重寫一下,提升代碼質(zhì)量。
爬蟲(chóng)啟動(dòng)之后不定期會(huì)出現(xiàn)驗(yàn)證碼反爬蟲(chóng),需要輸入驗(yàn)證碼才能繼續(xù),于是想在需要輸入驗(yàn)證碼時(shí)推送一個(gè)消息給用戶,讓用戶輸入驗(yàn)證碼以繼續(xù)爬蟲(chóng)的整個(gè)流程。我們平時(shí)用釘釘辦公,釘釘群有個(gè)機(jī)器人,很方便于是就實(shí)現(xiàn)了一個(gè)通過(guò)釘釘?shù)娜簷C(jī)器人實(shí)現(xiàn)消息推送。
實(shí)現(xiàn)
代碼是 ts 實(shí)現(xiàn)的,用了 request 發(fā)起http請(qǐng)求,具體參數(shù)參考釘釘官方文檔,只實(shí)現(xiàn)了文本消息的推送,其它消息類似,再進(jìn)行一層封裝,實(shí)現(xiàn)代碼如下:
import * as request from "request"; import * as log4js from "log4js"; const logger = log4js.getLogger("DingdingBot"); const ApplicationTypeHeader:string = "application/json;charset=utf-8"; // DingdingBot // https://open-doc.dingtalk.com/microapp/serverapi2/qf2nxq export class DingdingBot{ private readonly _webhookUrl:string; constructor(webhookUrl:string){ this._webhookUrl = webhookUrl; } public pushMsg (msg: string, atMobiles?: Array<string>): boolean{ try { let options: request.CoreOptions = { headers: { "Content-Type": ApplicationTypeHeader }, json: { "msgtype": "text", "text": { "content": msg }, "at": { "atMobiles": atMobiles == null ? [] : atMobiles, "isAtAll": false } } }; request.post(this._webhookUrl, options, function(error, response, body){ logger.debug(`push msg ${msg}, response: ${JSON.stringify(body)}`); }); } catch(err) { console.error(err); return false; } } }
使用方式:
// botWebhookUrl 為對(duì)應(yīng)釘釘機(jī)器人的 webhook 地址 let bot = new DingdingBot(botWebhookUrl);; // 直接推送消息 bot.pushMsg("測(cè)試消息"); // 推送消息并 @ 某些人 var mobiles = new Array<string>(); mobiles.push("13255573334"); bot.pushMsg("測(cè)試消息并@", mobiles);
總結(jié)
以上所述是小編給大家介紹的nodejs通過(guò)釘釘群機(jī)器人推送消息的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
Nodejs?http模塊返回內(nèi)容中文亂碼問(wèn)題及解決
這篇文章主要介紹了Nodejs?http模塊返回內(nèi)容中文亂碼問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12基于docker搭建node環(huán)境開(kāi)發(fā)服務(wù)器全過(guò)程
這篇文章主要給大家介紹了關(guān)于如何基于docker搭建node環(huán)境開(kāi)發(fā)服務(wù)器的相關(guān)資料,本文將采用docker技術(shù)部署一個(gè)簡(jiǎn)單的nodejs應(yīng)用,文中通過(guò)圖文以及代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11詳解基于node的前端項(xiàng)目編譯時(shí)內(nèi)存溢出問(wèn)題
本篇文章主要介紹了基于node的前端項(xiàng)目編譯時(shí)內(nèi)存溢出問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08剖析Node.js異步編程中的回調(diào)與代碼設(shè)計(jì)模式
這篇文章主要介紹了Node.js異步編程中的回調(diào)與代碼設(shè)計(jì)模式,雖然大多數(shù)場(chǎng)合回調(diào)編寫時(shí)的長(zhǎng)串括號(hào)不怎么好看,但Node的異步性能確實(shí)很好,需要的朋友可以參考下2016-02-02基于html5和nodejs相結(jié)合實(shí)現(xiàn)websocket即使通訊
HTML5 擁有許多引人注目的新特性,如 Canvas、本地存儲(chǔ)、多媒體編程接口、WebSocket 等等。雖然現(xiàn)在大家把它捧的很火的樣子,但是個(gè)人認(rèn)為它還需要其他平臺(tái)的支持才能真正的"火起來(lái)"2015-11-11node.js實(shí)現(xiàn)博客小爬蟲(chóng)的實(shí)例代碼
這篇文章通過(guò)實(shí)例代碼來(lái)給大家介紹如何利用node.js實(shí)現(xiàn)博客小爬蟲(chóng),有需要的朋友們可以直接運(yùn)用文中給出的實(shí)例代碼來(lái)進(jìn)行實(shí)踐學(xué)習(xí),感興趣的朋友們下面來(lái)一起看看吧。2016-10-10nodeJS(express4.x)+vue(vue-cli)構(gòu)建前后端分離實(shí)例(帶跨域)
這篇文章主要介紹了nodeJS(express4.x)+vue(vue-cli)構(gòu)建前后端分離實(shí)例(帶跨域) ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07