当前位置: 移动技术网 > IT编程>开发语言>.net > 微信公众平台开发之自定义菜单.Net代码解析

微信公众平台开发之自定义菜单.Net代码解析

2017年12月12日  | 移动技术网IT编程  | 我要评论

神武火德星君,qq 空间登录,leleshop

用户自定义菜单制作时,需要用到access_token,我们直接使用前面讲解的isexistaccess_token()函数。我理解的微信公共平台里面菜单分为button和sub_button,即菜单和子菜单,这些菜单都有一个name的属性,类别分为click和view,click类有key属性;而view类有url属性,含有子菜单的菜单没有key属性也没有url属性。这些情况可以从下面的例子看出来。

 public void mymenu()
  {
   string weixin1 = "";
   weixin1 = @" {
  ""button"":[
  { 
   ""type"":""click"",
   ""name"":""你好!"",
   ""key"":""hello""
  },
  {
   ""type"":""view"",
   ""name"":""公司简介"",
   ""url"":""http://www.4ugood.net""
  },
  {
   ""name"":""产品介绍"",
   ""sub_button"":[
   {
    ""type"":""click"",
    ""name"":""产品1"",
    ""key"":""p1""
   },
   {
    ""type"":""click"",
    ""name"":""产品2"",
    ""key"":""p2""
   }]
  }]
 }
";

   string access_token = isexistaccess_token();
   string i = getpage("https://api.weixin.qq.com/cgi-bin/menu/create?access_token="+access_token, weixin1);
   response.write(i);
  }

在你页面的 page_load 函数中调用这个mymenu(),就可以显示出来了。
既然显示出来了,菜单的时间如何出发呢?我们已经了解到了如果类型为view的话,他有url属性,这个不需要处理,点击后会直接跳转到你设定的url的页面,下面我来看看如何触发click吧,按照微信的文档可以用(!string.isnullorempty(wx.eventname) && wx.eventname.trim() == "click")来判断,我把之前的代码改造一下,同时把在getwxmessage()方法中把eventkey的值附上,wx.eventkey = xml.selectsinglenode("xml").selectsinglenode("eventkey").innertext;  

protected void page_load(object sender, eventargs e)
  {
  
   mymenu();
   wxmessage wx = getwxmessage();
   string res = "";

   if (!string.isnullorempty(wx.eventname) && wx.eventname.trim() == "subscribe")
   {
    string content = "";
    content = "/:rose欢迎北京永杰友信科技有限公司/:rose\n直接回复“你好”";
    res = sendtextmessage(wx, content);
   }
   else if (!string.isnullorempty(wx.eventname) && wx.eventname.trim() == "click")
   {
    if(wx.eventkey=="hello")
     res = sendtextmessage(wx, "你好,欢迎使用北京永杰友信科技有限公司公共微信平台!");
    if(wx.eventkey=="p1")
     res = sendtextmessage(wx, "你好,点击了产品1");
    if(wx.eventkey=="p2")
     res = sendtextmessage(wx, "你好,点击了产品2");
   }
   else
   {
    if (wx.msgtype == "text" && wx.content == "你好")
    {
     res = sendtextmessage(wx, "你好,欢迎使用北京永杰友信科技有限公司公共微信平台!");
    }
    else if (wx.msgtype == "voice")
    {
     res = sendtextmessage(wx, wx.recognition);
    }
    else
    {
     res = sendtextmessage(wx, "你好,未能识别消息!");
    }
   }

   response.write(res);
  }



  private wxmessage getwxmessage()
  {
   wxmessage wx = new wxmessage();
   streamreader str = new streamreader(request.inputstream, system.text.encoding.utf8);
   xmldocument xml = new xmldocument();
   xml.load(str);
   wx.tousername = xml.selectsinglenode("xml").selectsinglenode("tousername").innertext;
   wx.fromusername = xml.selectsinglenode("xml").selectsinglenode("fromusername").innertext;
   wx.msgtype = xml.selectsinglenode("xml").selectsinglenode("msgtype").innertext;
   if (wx.msgtype.trim() == "text")
   {
    wx.content = xml.selectsinglenode("xml").selectsinglenode("content").innertext;
   }
   if (wx.msgtype.trim() == "event")
   {
    wx.eventname = xml.selectsinglenode("xml").selectsinglenode("event").innertext;
    wx.eventkey = xml.selectsinglenode("xml").selectsinglenode("eventkey").innertext;
   }
   if (wx.msgtype.trim() == "voice")
   {
    wx.recognition = xml.selectsinglenode("xml").selectsinglenode("recognition").innertext;
   }
   
   return wx;
  }




/// <summary> 
  /// 发送文字消息 
  /// </summary> 
  /// <param name="wx">获取的收发者信息</param> 
  /// <param name="content">内容</param> 
  /// <returns></returns> 
  private string sendtextmessage(wxmessage wx, string content)
  {
   string res = string.format(@"<xml>
         <tousername><![cdata[{0}]]></tousername>
         <fromusername><![cdata[{1}]]></fromusername>
         <createtime>{2}</createtime>
         <msgtype><![cdata[text]]></msgtype>
         <content><![cdata[{3}]]></content>
         </xml> ",
    wx.fromusername, wx.tousername, datetime.now, content);
   return res;
  }

 这样就可以相应你的菜单事件了,我上面的代码写的有很多可以优化的地方,这里主要以简介为主,以后我们会逐渐搭建起一个微信公共平台的.net框架,什么菜单类,消息类等等。 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网