树莓派 微信控制GPIO

1.申请公共平台测试帐号

截图00.png
截图01.png

2.获取access_token

截图02.png

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
把APPID和APPSECRET换成图上的,即可获取Access_token

3.创建自定义菜单

使用网页调试工具调试该接口

打开调试接口, body部分填写

{
    "menu": {
        "button": [
            {
                "type": "click", 
                "name": "查询设备", 
                "key": "V1001_TODAY_MUSIC", 
                "sub_button": [ ]
            }, 
            {
                "name": "菜单", 
                "sub_button": [
                    {
                        "type": "click", 
                        "name": "第一路:开", 
                        "key": "v1_on", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "click", 
                        "name": "第一路:关", 
                        "key": "v1_off", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "click", 
                        "name": "第二路-开", 
                        "key": "v2_on", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "click", 
                        "name": "第一路-关", 
                        "key": "v2_off", 
                        "sub_button": [ ]
                    }
                ]
            }
        ]
    }
}

菜单效果

webwxgetmsgimg.jpg

4.回到树莓派上

4.1 安装webpy
pip install web.py

4.2 创建main.py文件
sudo nano mainpy

 #!/usr/local/bin/python
#coding=utf-8
import web
from handle import Handle

urls = (
 '/wx', 'Handle',
)

if __name__ == '__main__':
 app = web.application(urls, globals())
 app.run()

4.3 创建receive.py
sudo nano receive.py

  # -*- coding: utf-8 -*-
# filename: receive.py
import xml.etree.ElementTree as ET

def parse_xml(web_data):
  if len(web_data) == 0:
      return None
  xmlData = ET.fromstring(web_data)
  msg_type = xmlData.find('MsgType').text
  if msg_type == 'text':
      return TextMsg(xmlData)
  elif msg_type == 'image':
      return ImageMsg(xmlData)
  elif msg_type == 'event':
      return gpioMsg(xmlData)

class Msg(object):
  def __init__(self, xmlData):
      self.ToUserName = xmlData.find('ToUserName').text
      self.FromUserName = xmlData.find('FromUserName').text
      self.CreateTime = xmlData.find('CreateTime').text
      self.MsgType = xmlData.find('MsgType').text


class gpioMsg(Msg):
  def __init__(self, xmlData):
      Msg.__init__(self, xmlData)
      self.EventKey = xmlData.find('EventKey').text.encode("utf-8")

class TextMsg(Msg):
  def __init__(self, xmlData):
      Msg.__init__(self, xmlData)
      self.MsgId = xmlData.find('MsgId').text
      self.Content = xmlData.find('Content').text.encode("utf-8")

class ImageMsg(Msg):
  def __init__(self, xmlData):
      Msg.__init__(self, xmlData)
      self.MsgId = xmlData.find('MsgId').text
      self.PicUrl = xmlData.find('PicUrl').text
      self.MediaId = xmlData.find('MediaId').text

4.4 创建 reply.py
sudo nano reply.py

     # -*- coding: utf-8 -*-
# filename: reply.py
import time


class Msg(object):
    def __init__(self):
        pass

    def send(self):
        return "success"


class TextMsg(Msg):
    def __init__(self, toUserName, fromUserName, content):
        self.__dict = dict()
        self.__dict['ToUserName'] = toUserName
        self.__dict['FromUserName'] = fromUserName
        self.__dict['CreateTime'] = int(time.time())
        self.__dict['Content'] = content

    def send(self):
        XmlForm = """
        <xml>
        <ToUserName><![CDATA[{ToUserName}]]></ToUserName>
        <FromUserName><![CDATA[{FromUserName}]]></FromUserName>
        <CreateTime>{CreateTime}</CreateTime>
        <MsgType><![CDATA[text]]></MsgType>
        <Content><![CDATA[{Content}]]></Content>
        </xml>
        """
        return XmlForm.format(**self.__dict)


class ImageMsg(Msg):
    def __init__(self, toUserName, fromUserName, mediaId):
        self.__dict = dict()
        self.__dict['ToUserName'] = toUserName
        self.__dict['FromUserName'] = fromUserName
        self.__dict['CreateTime'] = int(time.time())
        self.__dict['MediaId'] = mediaId

    def send(self):
        XmlForm = """
        <xml>
        <ToUserName><![CDATA[{ToUserName}]]></ToUserName>
        <FromUserName><![CDATA[{FromUserName}]]></FromUserName>
        <CreateTime>{CreateTime}</CreateTime>
        <MsgType><![CDATA[image]]></MsgType>
        <Image>
        <MediaId><![CDATA[{MediaId}]]></MediaId>
        </Image>
        </xml>
        """
        return XmlForm.format(**self.__dict)

4.5 创建handel.py
sudo nano handle.py

 注意token的填写
#!/usr/local/bin/python
#coding=utf-8
import hashlib
import reply
import receive
import web
import gpio
class Handle(object):

    def GET(self):
        try:
            for k, v in web.ctx.env.items():
                print(k, v)
            data = web.input()
            if len(data) == 0:
                return "hello, this is handle view"
            signature = data.signature
            timestamp = data.timestamp
            nonce = data.nonce
            echostr = data.echostr
            token = "xxxxxxxxxxxxxxxxxx" #请按照公众平台官网\基本配置中信息填写

            list = [token, timestamp, nonce]
            list.sort()
            sha1 = hashlib.sha1()
            map(sha1.update, list)
            hashcode = sha1.hexdigest()
            print ("handle/GET func: hashcode, signature: ", hashcode, signature)
            if hashcode == signature:
                return echostr
            else:
                return ""
        except Exception as Argument:
            return Argument

    def POST(self):
        try:
            webData = web.data()
            print "Handle Post webdata is ", webData  # 后台打日志
            recMsg = receive.parse_xml(webData)
            if isinstance(recMsg, receive.Msg):
                toUser = recMsg.FromUserName
                fromUser = recMsg.ToUserName
                if recMsg.MsgType == 'text':
                    content = "test"
                    replyMsg = reply.TextMsg(toUser, fromUser, content)
                    return replyMsg.send()
                if recMsg.MsgType == 'image':
                    mediaId = recMsg.MediaId
                    replyMsg = reply.ImageMsg(toUser, fromUser, mediaId)
                    return replyMsg.send()

                if recMsg.MsgType == 'event':
                    if  recMsg.EventKey == 'v1_on':
                        print '第1一路:开'
                        gpio.handel(16,1)
                        print '成功'
                        content = "成功打开第一路灯"
                        replyMsg = reply.TextMsg(toUser, fromUser, content)
                        return replyMsg.send()
                    if  recMsg.EventKey == 'v1_off':
                        gpio.handel(16, 0)
                        print '第1一路:关'
                        content = "成功关闭第一路灯"
                        replyMsg = reply.TextMsg(toUser, fromUser, content)
                        return replyMsg.send()
                    if  recMsg.EventKey == 'v2_on':
                        gpio.handel(20, 1)
                        print '第二路:开'
                        content = "成功打开第二路灯"
                        replyMsg = reply.TextMsg(toUser, fromUser, content)
                        return replyMsg.send()
                    if  recMsg.EventKey == 'v2_off':
                        print '第二路:关'
                        gpio.handel(20, 0)
                        content = "成功关闭第二路灯"
                        replyMsg = reply.TextMsg(toUser, fromUser, content)
                        return replyMsg.send()

            else:
                print "暂且不处理"
                return "success"
        except Exception, Argment:
            return Argment


4.6 sudo nano gpio.py

#!/usr/local/bin/python
#coding=utf-8
try:
    import RPi.GPIO as GPIO
except RuntimeError:
    print("Error importing RPi.GPIO!  This is probably because you need superuser privileges.  You can achieve this by using 'sudo' to run your script")

GPIO.setmode(GPIO.BCM)
GPIO.setwarnings(False)
def handel(LED,power):
    GPIO.setup(LED,GPIO.OUT)
    GPIO.output(LED,power)

if __name__ == '__main__':
   handel(16,0)

4.7 sudo python main.py 80

推荐一个linux命令行网站:https://rootopen.com

需要内网穿透请看http://www.jianshu.com/p/c76aba56abe2

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容