C# 微信公众平台开发(2)-- 微信菜单

上一篇了解微信开发者中心 URL的配置验证;

  1. 验证成功后,就可以对获取的接口权限进行操作

自定义菜单接口可实现多种类型按钮,用的比较多的是

1.click:点击推事件

   用户点击click类型按钮后,微信服务器会通过消息接口推送消息类型为event 的结构给开发者(参考消息接口指南),并且带上按钮中开发者填写的key值,开发者可以通过自定义的key值与用户进行交互;

2、view:跳转URL

  用户点击view类型按钮后,微信客户端将会打开开发者在按钮中填写的网页URL,可与网页授权获取用户基本信息接口结合,获得用户基本信息。

自定义菜单接口调用:

  http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN

  ACCESS_TOKEN 需要通过接口获取

由于ACCESS_TOKEN 一天只能调用 2000,可以将ACCESS_TOKEN  保存起来,有效时间内不需要重新调用接口

  /// <summary>
        /// 获取凭证接口
        /// </summary>
        /// <param name="grant_type">获取access_token填写client_credential</param>
        /// <param name="appid">第三方用户唯一凭证</param>
        /// <param name="secret">第三方用户唯一凭证密钥,既appsecret</param>
        /// <returns></returns>
        public static string GetAccessToken(string appid, string secret)
        {
            string token = OperationXml.GetXMLToken();
            if (token == "")
            {
                string strJson = RequestUrl(string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", appid, secret));
                token = GetJsonValue(strJson, "access_token");
                OperationXml.UpdateXMLToken(token, DateTime.Now);
            }

            return token;
        }
 public static string RequestUrl(string strUrl)
        {
            // 设置参数
            HttpWebRequest request = WebRequest.Create(strUrl) as HttpWebRequest;
            CookieContainer cookieContainer = new CookieContainer();
            request.CookieContainer = cookieContainer;
            request.AllowAutoRedirect = true;
            request.Method = "POST";
            request.ContentType = "text/html";
            request.Headers.Add("charset", "utf-8");

            //发送请求并获取相应回应数据
            HttpWebResponse response = request.GetResponse() as HttpWebResponse;
            //直到request.GetResponse()程序才开始向目标网页发送Post请求
            Stream responseStream = response.GetResponseStream();
            StreamReader sr = new StreamReader(responseStream, Encoding.UTF8);
            //返回结果网页(html)代码
            string content = sr.ReadToEnd();
            return content;
        }

#region 获取Json字符串某节点的值

        /// <summary>
        /// 获取Json字符串某节点的值
        /// </summary>
        public static string GetJsonValue(string jsonStr, string key)
        {
            string result = string.Empty;
            if (!string.IsNullOrEmpty(jsonStr))
            {
                key = "\"" + key.Trim(‘"‘) + "\"";
                int index = jsonStr.IndexOf(key) + key.Length + 1;
                if (index > key.Length + 1)
                {
                    //先截逗号,若是最后一个,截“}”号,取最小值
                    int end = jsonStr.IndexOf(‘,‘, index);
                    if (end == -1)
                    {
                        end = jsonStr.IndexOf(‘}‘, index);
                    }

                    result = jsonStr.Substring(index, end - index);
                    result = result.Trim(new char[] { ‘"‘, ‘ ‘, ‘\‘‘ }); //过滤引号或空格
                }
            }
            return result;
        }

        #endregion

  /// <summary>
        /// 获取XML文件路径
        /// </summary>
        public static string xmlName = AppDomain.CurrentDomain.BaseDirectory + @"\AccessToken.xml";

        /// <summary>
        /// 读取XML  Token
        /// </summary>
        /// <param name="xmlUrl"></param>
        /// <returns></returns>
        public static string GetXMLToken()
        {
            try
            {
                XmlDocument xmlDoc = new XmlDocument();
                xmlDoc.Load(xmlName);

                XmlNode xn = xmlDoc.SelectSingleNode("ACCESS_TOKEN");
                XmlElement xe = (XmlElement)xn;//将子节点类型转换为XmlElement类型
                string Token = "";
                string CreateTime = "";
                foreach (XmlNode xn1 in xe)//遍历
                {
                    XmlElement xe2 = (XmlElement)xn1;//转换类型
                    if (xe2.Name == "Token")//如果找到
                    {
                        Token = xe2.InnerText;//则修改
                    }
                    if (xe2.Name == "CreateTime")//如果找到
                    {
                        CreateTime = xe2.InnerText;//则修改
                    }
                }

                int seconds = 0;

                if (CreateTime.Trim() != "")
                {
                    DateTime ct = Convert.ToDateTime(CreateTime);
                    TimeSpan ts = (DateTime.Now - ct);
                    seconds = ts.Milliseconds;
                }
                LogTextHelper.WriteLogToFile("Token:" + Token);
                if (seconds > 7200 || seconds == 0)
                {
                    return "";
                }
                else
                {
                    return Token;
                }
            }
            catch (Exception ex)
            {
                LogTextHelper.WriteLogToFile("异常:" + ex.ToString());
                return "";
            }
        }

        /// <summary>
        /// 修改Token
        /// </summary>
        /// <param name="token"></param>
        /// <param name="createTime"></param>
        public static void UpdateXMLToken(string token, DateTime createTime)
        {
            XmlDocument xmlDoc = new XmlDocument();
            xmlDoc.Load(xmlName);

            XmlNode xn = xmlDoc.SelectSingleNode("ACCESS_TOKEN");
            XmlElement xe = (XmlElement)xn;//将子节点类型转换为XmlElement类型 

            foreach (XmlNode xn1 in xe)//遍历
            {
                XmlElement xe2 = (XmlElement)xn1;//转换类型
                if (xe2.Name == "Token")//如果找到
                {
                    xe2.InnerText = token;//则修改
                }
                if (xe2.Name == "CreateTime")//如果找到
                {
                    xe2.InnerText = createTime.ToString();//则修改
                }
            }
            xmlDoc.Save(xmlName);

        }

获取Token

  1   #region 创建菜单
  2
  3         public string CreateMenuPage(string posturl, string postData)
  4         {
  5             Stream outstream = null;
  6             Stream instream = null;
  7             StreamReader sr = null;
  8             HttpWebResponse response = null;
  9             HttpWebRequest request = null;
 10             Encoding encoding = Encoding.UTF8;
 11             byte[] data = encoding.GetBytes(postData);
 12             // 准备请求...
 13             try
 14             {
 15                 // 设置参数
 16                 request = WebRequest.Create(posturl) as HttpWebRequest;
 17                 CookieContainer cookieContainer = new CookieContainer();
 18                 request.CookieContainer = cookieContainer;
 19                 request.AllowAutoRedirect = true;
 20                 request.Method = "POST";
 21                 request.ContentType = "application/x-www-form-urlencoded";
 22                 request.ContentLength = data.Length;
 23                 outstream = request.GetRequestStream();
 24                 outstream.Write(data, 0, data.Length);
 25                 outstream.Close();
 26                 //发送请求并获取相应回应数据
 27                 response = request.GetResponse() as HttpWebResponse;
 28                 //直到request.GetResponse()程序才开始向目标网页发送Post请求
 29                 instream = response.GetResponseStream();
 30                 sr = new StreamReader(instream, encoding);
 31                 //返回结果网页(html)代码
 32                 string content = sr.ReadToEnd();
 33                 string err = string.Empty;
 34                 Response.Write(content);
 35                 return content;
 36             }
 37             catch (Exception ex)
 38             {
 39                 string err = ex.Message;
 40                 return string.Empty;
 41             }
 42         }
 43
 44         #endregion
 45
 46         #region 删除菜单
 47
 48         public JsonResult DelMenu()
 49         {
 50             string postUrl = "https://api.weixin.qq.com/cgi-bin/menu/delete?access_token={0}";
 51             postUrl = string.Format(postUrl, CommonApi.GetAccessToken(strAppID, strAppSecret));
 52             string menuInfo = getMenuInfo();
 53             string result = CommonApi.PostWebRequest(postUrl, menuInfo);
 54
 55             return Json(result, JsonRequestBehavior.AllowGet);
 56         }
 57
 58         #endregion
 59
 60         #region 获取菜单
 61
 62         public string GetMenuList(string posturl)
 63         {
 64             Stream instream = null;
 65             StreamReader sr = null;
 66             HttpWebResponse response = null;
 67             HttpWebRequest request = null;
 68             Encoding encoding = Encoding.UTF8;
 69             // 准备请求...
 70             try
 71             {
 72                 // 设置参数
 73                 request = WebRequest.Create(posturl) as HttpWebRequest;
 74                 CookieContainer cookieContainer = new CookieContainer();
 75                 request.CookieContainer = cookieContainer;
 76                 request.AllowAutoRedirect = true;
 77                 request.Method = "GET";
 78                 request.ContentType = "application/x-www-form-urlencoded";
 79                 //发送请求并获取相应回应数据
 80                 response = request.GetResponse() as HttpWebResponse;
 81                 //直到request.GetResponse()程序才开始向目标网页发送Post请求
 82                 instream = response.GetResponseStream();
 83                 sr = new StreamReader(instream, encoding);
 84                 //返回结果网页(html)代码
 85                 string content = sr.ReadToEnd();
 86                 string err = string.Empty;
 87                 Response.Write(content);
 88                 return content;
 89             }
 90             catch (Exception ex)
 91             {
 92                 string err = ex.Message;
 93                 return string.Empty;
 94             }
 95         }
 96
 97         #endregion
 98
 99  private string getMenuInfo()
100         {
101  {
102      "button":[
103      {
104           "type":"click",
105           "name":"今日歌曲",
106           "key":"V1001_TODAY_MUSIC"
107       },
108       {
109            "name":"菜单",
110            "sub_button":[
111            {
112                "type":"view",
113                "name":"搜索",
114                "url":"http://www.soso.com/"
115             },
116             {
117                "type":"view",
118                "name":"视频",
119                "url":"http://v.qq.com/"
120             },
121             {
122                "type":"click",
123                "name":"赞一下我们",
124                "key":"V1001_GOOD"
125             }]
126        }]
127  }
128        }    

菜单操作

发布服务器,执行下,在微信公众号上就可以看到自己定义的菜单了

时间: 2024-08-23 17:57:12

C# 微信公众平台开发(2)-- 微信菜单的相关文章

微信公众平台开发(99) 自定义菜单获取OpenID

关键字 微信公众平台 自定义菜单 OpenID作者:方倍工作室原文:http://www.cnblogs.com/txw1958/p/weixin-menu-get-openid.html 在这篇微信公众平台开发教程中,我们将介绍如何在自定义菜单中获得用户的OpenID. 本篇开发教程的实质是微信自定义菜单及OAuth2.0授权的灵活运用. 本文分为以下四个部分: 拥有高级接口权限时的获取(基于view事件) 没有高级接口权限时的获取(基于click事件) 一.拥有高级接口权限 拥有高级接口权限

微信公众平台开发(102) 微信支付账号体系

本文介绍微信支付账号体系各参数. 商户在微信公众平台提交申请资料以及银行账户资料,资料审核通过并签约后,可以获得表6-4所示帐户(包含财付通的相关支付资金账户),用于公众帐号支付. 帐号 作用 appId 公众帐号身份的唯一标识.审核通过后,在微信发送的邮件中查看. appSecret 公众帐号支付请求中用于加密的密钥Key,可验证商户唯一身份,PaySignKey对应于支付场景中的appKey值.审核通过后,在微信发送的邮件中查看. paySignKey 除了支付请求需要用到paySignKe

微信公众平台开发(101) 微信支付URL配置

本文介绍微信支付申请时如何设置授权目录及URL. 一.选择支付类型 目前有两种支付类型 JS API网页支付 Native原生支付 如果没有特殊要求,两种都勾选. 二.支付授权目录 目前可以选择http还是https协议,没有特别要求,选择http.对安全要求比较高的企业,请选择https. 支付授权目录填写自己公司的域名加上目录,目录可以是不存在的目录,例如wxpay. 一个完整的目录参考如下: http://www.doucube.com/wxpay/ 蓝色部分表示要选择的. 红色部分表示要

【微信公众平台开发】微信刮刮乐,解决三星兼容性问题

刮刮乐jquery插件:wScratchPad 完整项目资源下载:点击打开链接 运用wScratchPad插件很快弄出刮刮乐的效果,代码如下: <!DOCTYPE html> <html> <head> <meta CHARSET="UTF-8"> <title>刮刮乐</title> <script type="text/javascript" src="./inc/jquer

【微信公众平台开发】微信幸运大转盘

需要js插件(下载包地址:http://download.csdn.net/detail/wyz365889/7798255): jquery jQueryRotate.2.2.js jquery.easing.min.js 前端显示代码: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <meta name=

微信公众平台开发(109) 个性化菜单

关键字:微信公众平台 个性化菜单 conditionalmenu 作者:方倍工作室 原文:http://www.cnblogs.com/txw1958/p/weixin-menu-conditional.html 为了帮助公众号实现灵活的业务运营,微信公众平台新增了个性化菜单接口,开发者可以通过该接口,让公众号的不同用户群体看到不一样的自定义菜单.该接口开放给已认证订阅号和已认证服务号. 在这篇微信公众平台开发教程中,我们将介绍如何开发个性化菜单的功能. 一.个性化菜单接口 开发者可以通过以下条

微信公众平台开发(104) 自定义菜单扫一扫、发图片、发地理位置

关键字:微信公众平台 自定义菜单 扫一扫 发图片 发地理位置作者:方倍工作室原文:http://www.cnblogs.com/txw1958/p/weixin-menu-new-type.html 自定义菜单能够帮助公众号丰富界面,让用户更好更快地理解公众号的重要功能.微信增加了点击菜单后调起扫一扫(支持二维码/一维码).发图片.发地理位置的能力,需开发实现.原有自定义菜单开发权限的公众号,均可获得以上能力. 在这篇微信公众平台开发教程中,我们将介绍如何在自定义菜单上开发扫一扫.发图片.发地理

微信公众平台开发(110) 微信连Wi-Fi

关键字:微信公众平台 微信连Wi-Fi 微信 WiFi 硬件鉴权作者:方倍工作室 原文:http://www.cnblogs.com/txw1958/p/weixin-wifi.html 微信连Wi-Fi是为商家的线下场所提供一套完整和便捷的微信连Wi-Fi的方案.商家接入微信连Wi-Fi后,顾客无需输入繁琐的Wi-Fi密码,通过微信扫二维码等方式即可快速上网.微信连Wi-Fi还帮助商家打造个性化服务,如提供微信顶部常驻入口.商家主页展示.连网后公众号下发消息等.因此,微信连Wi-Fi既可以极大

微信公众平台开发(121) 微信二维码海报

关键字:微信公众平台 二维码 海报作者:方倍工作室原文: http://www.cnblogs.com/txw1958/p/weixin-poster.html 本文介绍微信公众平台下二维码海报的开发过程. 一.微信二维码海报介绍 微信二维码海报是指在海报中嵌入和微信用户关联的参数二维码的海报,用户分享推广之后,新用户可以被统计为被推广人员数,从而达到增加粉丝的传播效果.其使用场景如下:   二.开发流程 在微信二维码海报生成中,需要用到以下信息 1. 自定义菜单中设置一个菜单项,点击后返回二维

微信公众平台开发-- 关闭微信浏览器

在这篇微信公众平台开发教程中,我们将介绍如何使用微信JS接口关闭微信内置浏览器返回到微信聊天窗口界面. 微信的JS接口目前已公布了三种:右上角按钮/底部导航栏/用户网络状态,另外转发到朋友圈和分享到好友也可以使用JS接口来定义. 而关闭微信浏览器可以使用 WeixinJSBridge.call('closeWindow');" 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 2 &l