×

WhatsApp通知站开源分享

消耗积分:0 | 格式:zip | 大小:0.12 MB | 2022-12-09

分享资料个

描述

描述

我正在使用由我的 Twilio 帐户和号码提供的 WhatsApp Business API 创建一个自我回复的订单机器人。在实现我表面上的目标后,我考虑使用 Twilio WhatsApp Helper Library 将信息(数据包)作为 WhatsApp 消息从 NodeMCU 发送到我的手机,最初是通过 webhook 传输信息。通过这种方式,我能够通过 HTTP Get 请求使用来自 NodeMCU 的数据创建模板消息,以通过 Twilio API 将它们作为 WhatsApp 消息发送。对于我网站的订阅者,我在 Dashboard 上实施了一个名为 WhatsApp WebHook 的新 Web 应用程序,它使用您的晶石生成一个唯一的 webhook 路径,如下所述。如果你想使用本地主机或任​​何其他链接提供程序来创建 webhook,我在下面分享了这个应用程序的源代码,但首先,

我想每半分钟获取三个变量作为 WhatsApp 消息——温度、湿度和运动。换句话说,WhatsApp Notification Station 每半分钟将这三个变量发送到 webhook 以组合为模板 WhatsApp 消息。我使用 DHT11 温湿度传感器同时获取温度和湿度,并使用 HC-SR04 超声波传感器检测任何移动(非法侵入)。

首先,下载下面Arduino IDE所需的库,继续下面的步骤。

所需库:

对于 NodeMCU 板,请单击此处。

对于 DHT11 温湿度传感器,请单击此处。

 
poYBAGOSp8eAOAZeAAjDl_TOxD8492.jpg
 

适用于 WhatsApp 的 Twilio

要通过 Twilio API 发送 WhatsApp 消息,您唯一需要做的就是注册 Twilio 试用帐户。

注册后,使用您的 SID 和 Auth Token,您可以免费使用 WhatsApp 的 Twilio API。正如 Twilio 上所解释的那样,您需要将共享电话号码与您的手机连接起来才能启动 API 和 WhatsApp 模板消息。

如需更多信息并了解如何激活您的帐户,请单击下面的链接。

转到 Twilio。

您可以在此处使用我的推荐代码注册 Twilio

 
pYYBAGOSp8mAR8U2AACf2B9FPNE762.jpg
 
 
pYYBAGOSp82ALGjcAACjFPWcxpw370.jpg
 

如何创建一个webhook来传输数据包

在此项目中,webhook 通过 HTTP Get 请求从 NodeMCU 获取信息,以通过 Twilio WhatsApp API 将其发送到您的手机。

对于我网站的订阅者,我创建了一个名为 WhatsApp WebHook 的 Web 应用程序,它使用 TheAmplituhedron(我的网站)提供的晶石为每个帐户生成一个唯一的 Webhook。

通过使用此 Web 应用程序,您可以直接连接到您的 Twilio 帐户,以通过 ESP8266、Raspberry Pi 或与操作系统兼容的任何其他设备发送 WhatsApp 消息。

它只是一个简单的 webhook,需要下面定义的五个参数。

1)Twilio 账户 SID

2) Twilio 账户授权令牌

3) 消息正文

4)发件人:专用商务电话号码(共享)

5) 收件人:您的验证电话号码

注意:通常,您必须输入加号 (+) 和国家/地区代码,然后输入完整的电话号码,例如 +14081234567。

但是,当通过此 Web 应用程序 (WhatsApp WebHook) 将信息从您的设备发送到您的手机时,请输入 14081234567 之类的号码,不带加号 (+)。

有关此应用程序和获取自动生成的 webhook 的更多信息,请单击下面的链接。

转到 WhatsApp WebHook。

如果您想在本地主机或除 TheAmplituhedron 之外的任何其他服务器上为该项目创建一个 webhook,您可以复制 TheAmplituhedron 生成的 webhook 的源代码(在下面的代码共享)并更改上传到 NodeMCU 的代码中的 webhook 路径。

但是,要管理它,您必须从此处在您的目录中下载 Twilio PHP Helper Library

创建 webhook 并加入共享号码后,当 webhook 被触发时,您可以将数据包作为 WhatsApp 消息从 NodeMCU 传输到您已验证的手机。

虽然没有时长限制,但我还是选择每半分钟发送一次信息。

 
 
 
 
poYBAGOSp9aAYioEAAKZTErI2bM180.jpg
 
1 / 3
 
 
 
 
 
poYBAGOSp92AHcirAAKpD5hcgTY398.png
 
1 / 2
 

特征

NodeMCU 将三个变量——温度、湿度和运动——发送到 webhook 以组合为 WhatsApp 模板消息。并且,webhook 将该消息作为 WhatsApp 消息传输到您经过验证的手机。

1) 在串行监视器上监视变量以及消息是否通过 webhook 成功发送。

2) 在WhatsApp上显示DHT11温湿度传感器测得的温湿度。

“温度:值”和“湿度:值”

3) 如果 HC-SR04 超声波传感器在 WhatsApp 上检测到任何运动,则会收到通知。换句话说,如果有人擅自闯入。

“动静:未检测到动静!” 或“有人擅自闯入!”

 
pYYBAGOSp9-AflH8AABjVDMZK8U723.jpg
 
 
poYBAGOSp-KAbAvYAACa0ow4upk681.jpg
 
 
pYYBAGOSp-SAWBfYAAB8LjlgQEo931.jpg
 

连接

NodeMCU GPIO 引脚连接在下面的代码中有很好的解释。如下图所示进行连接。

我只是使用热胶枪将所有组件固定到一个旧塑料盒上,然后将它们连接到 NodeMCU(ESP-12E)。

注意:如果您的 HC-SR04 模块生成距离为 0,请为其提供外部 5V 电源。

 
 
 
 
poYBAGOSp_WAc_rvAANMR_Fozlk161.jpg
 
1 / 5
 
 
poYBAGOSqBGAcHxKAAnKCklh-M0455.jpg
 

影片

WhatsApp 通知站 | 示范

 

WhatsApp 通知站 | 传入的 WhatsApp 消息

 

 


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'WhatsApp通知站开源分享',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);