1 获取access token

此token是以后每次调用微信接口都会带上的票据,token是公众号全局唯一票据,在调用其他接口之前都需要先得到token,taoken长度至少512个字符,通常用string保存即可,有效时间2小时,重复获取后,前一次的token会失效

调用获取access token接口
http请求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
参数     是否必须     说明
grant_type     是     获取access_token填写client_credential
appid     是     第三方用户唯一凭证
secret     是     第三方用户唯一凭证密钥,即appsecret

       private Access_token_info GetTokenInfo()
{
string url = string.Format(urlFormat, appID, appSecret);
string json = Tool.HttpGet(url);
Access_token_info obj = Tool.DeserializeJson(json);
return obj;
}

成功返回时候,返回如下:
{"access_token":"ACCESS_TOKEN","expires_in":7200}
失败的时候返回如下
{"errcode":40013,"errmsg":"invalid appid"}
各字段说明
access_token     获取到的凭证
expires_in     凭证有效时间,单位:秒
errcode   错误编号
errmsg 错误信息说明

主要代码:

private const string urlFormat = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}";
string url = string.Format(urlFormat, appID, appSecret);
string json = Tool.GetHtml(url);
Access_token_info obj = Tool.ReadJson<Access_token_info>(json);

以上方法就是获取accesstoken,因为是get方法获取,需要我们封装了一个HTTPGET的方法,方法如下:

        public static String HttpGet(String Url)
{
string sException = null;
string sRslt = null;
WebResponse oWebRps = null;
WebRequest oWebRqst = WebRequest.Create(Url);
oWebRqst.Timeout = ;
try
{
oWebRps = oWebRqst.GetResponse();
}
catch (WebException e)
{
sException = e.Message.ToString();
}
catch (Exception e)
{
sException = e.ToString();
}
finally
{
if (oWebRps != null)
{
StreamReader oStreamRd = new StreamReader(oWebRps.GetResponseStream(), Encoding.GetEncoding("UTF-8"));
sRslt = oStreamRd.ReadToEnd();
oStreamRd.Close();
oWebRps.Close();
}
}
return sRslt;
}

2 JSON字符串反序列化

因为微信很多交互都是通过json来,所以我们很有必要封装一些方法来,对json进行序列化和反序列化

微信服务器返回数据大部分都是json格式的,所以为了方便我们使用,我们需要封装一个反序列化json的方法
我们使用Newtonsoft.Json 这个第三方组件,版本是.NET 2.0的
封装方法如下:

       public static T ReadJson(string jsonText)
{
return JavaScriptConvert.DeserializeObject(jsonText);
}

3 基类Page

因为我们的aspx页面很多东西都是公用一个的
比如appid apps等这些
所以我们可以封装一个基类page
如图
添加一个返回实体
Access_token_info 属性包含成功信息和错误信息
属性名称保留一样的 否则无法反序列化

4 获取微信服务器IP

有些时候,我们需要获取微信服务器的IP地址列表
这样的作用是开发者可以处于安全考虑,通过IP来判断是否是他人伪造数据
接口:https://api.weixin.qq.com/cgi-bin/getcallbackip?access_token=ACCESS_TOKEN
参数只需要一个:公众号的access_token
成功返回:
{
    "ip_list":["127.0.0.1","127.0.0.1"]
}
失败返回:{"errcode":40013,"errmsg":"invalid appid"}

            try
{
Access_token_info obj = GetTokenInfo();//先获取token信息
if (string.IsNullOrEmpty(obj.errcode))
{
string url = string.Format("https://api.weixin.qq.com/cgi-bin/getcallbackip?access_token={0}", obj.access_token);
string json = Tool.HttpGet(url);
Ip_listInfo listInfo = Tool.DeserializeJson(json);//获取ip列表
this.labelRes.Text = "Ip个数:" + listInfo.ip_list.Count() + " 第一个:" + listInfo.ip_list[];
}
else
{
this.labelRes.Text = obj.errcode + " " + obj.errmsg;
}
}
catch (Exception ex)
{
this.labelRes.Text = ex.Message;
}

获取IP列表的实现

5 添加自定义菜单,就是在公众号的地步添加菜单

自定义菜单最多包含3个一级菜单
每个一级菜单最多包含5个二级菜单
一级菜单最多4个汉字,二级菜单则最多7个汉字多出来的会用“...”代替
创建自定义菜单后,如果发现上一次拉取菜单的请求在5分钟以前,就会拉取一下菜单,如果菜单有更新,就会刷新客户端的菜单。测试时可以尝试取消关注公众账号后再次关注,则可以看到创建后的效果。
自定义菜单类型如下:

上面的这些类型有特殊的
添加View和Click 类型按钮
Post数据到下面接口
https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN 注意是https
因为需要推送到,post数据到微信接口,所以我们需要序列化json文本到微信接口
我们看一下菜单json文本
在序列化菜单对象成json的
时候,我们可以使用匿名

代码实现

            Infos.Menu m = new Infos.Menu();
//添加第一个菜单
m.button.Add(new { type = "click", name = "今日歌曲", key = "V1001_TODAY_MUSIC" });
//添加第二个菜单-包含子菜单
ArrayList sub = new ArrayList();
sub.Add(new { name = "搜索", type = "view", url = "http://www.soso.com/" });
sub.Add(new { name = "视频", type = "view", url = "http://v.qq.com/" });
sub.Add(new { name = "赞一d", type = "click", key = "V1001_GOOD" });
m.button.Add(new { name = "菜单", sub_button = sub });
//序列化成json文本
string json = Tool.SerializeJson(m); Access_token_info obj = GetTokenInfo();//先获取token信息
string url = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=" + obj.access_token; string textResponse = Tool.PostJson(json, url); //反序列化饭回来的结果
MenuCreateResultInfo menuResObj = Tool.DeserializeJson(textResponse); this.labelRes.Text = textResponse;

序列化菜单方法和使用

微信公众平台开发视频教程-03-获取Access Token和获取微信服务器IP,添加微信菜单的更多相关文章

  1. 微信公众号开发笔记1-获取Access Token

    获取你的Access Token a)可以采用网址的形式: 用appid和appsecert获得access token,接口为https://api.weixin.qq.com/cgi-bin/to ...

  2. 微信公众平台开发教程--方培工作室,PHP语言版本

    准备工作 微信公众平台的注册 介绍如何注册一个微信公众账号. 入门教程 微信公众平台开发入门教程 内容:1.申请SAE作为服务器; 2.启用开发模式; 3.微信公众平台PHP SDK; 4.接收发送消 ...

  3. PHP实现微信公众平台开发—基础篇

    PHP实现微信公众平台开发—基础篇 2 1课程介绍 2 2. 微信公众号账号介绍的申请流程详解 2 2.1微信三角色关系 2 2.2信息流的过程 2 2.4微信公众账号的认证 3 2.5订阅号的申请流 ...

  4. Senparc.Weixin.MP SDK 微信公众平台开发教程(十七):个性化菜单接口说明

    前不久微信上线了个性化菜单接口,Senparc.Weixin SDK也已经同步更新. 本次更新升级Senparc.Weixin.MP版本到v13.5.2,依赖Senparc.Weixin版本4.5.4 ...

  5. Senparc.Weixin.MP SDK 微信公众平台开发教程(五):使用Senparc.Weixin.MP SDK

    Senparc.Weixin.MP SDK已经涵盖了微信6.x的所有公共API. 整个项目的源代码以及已经编译好的程序集可以在这个项目中获取到:https://github.com/JeffreySu ...

  6. Senparc.Weixin.MP SDK 微信公众平台开发教程(七):解决用户上下文(Session)问题

    从这篇文章中我们已经了解了微信公众平台消息传递的方式,这种方式有一个先天的缺陷:不同用户的请求都来自同一个微信服务器,这使得常规的Session无法使用(始终面对同一个请求对象,况且还有对方服务器Co ...

  7. Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明

    一.基础说明 这里说的“通用接口(CommonAPIs)”是使用微信公众账号一系列高级功能的必备验证功能(应用于开发模式). 我们通过微信后台唯一的凭证,向通用接口发出请求,得到访问令牌(Access ...

  8. Senparc.Weixin.MP SDK 微信公众平台开发教程(九):自定义菜单接口说明

    上一篇<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>介绍了如何通过通用接口获取AccessToken,有了AccessToken,我们就可以来操作 ...

  9. Senparc.Weixin.MP SDK 微信公众平台开发教程(十一):高级接口说明

    这里所说的高级接口是指面向通过认证的服务号开通的高级功能. 高级功能大致可以分类为: 用户接口 分组接口 客服接口(有别于之前介绍的多客服) 群发接口 多媒体接口 二维码接口 模板消息接口(不是所有账 ...

随机推荐

  1. when you're gone

      when you're gone ——艾薇儿 I always needed time on my own 我真的需要一些独处的时间 I never thought I'd need you th ...

  2. Java 第六章 循环结构2

    循环结构 2 会使用 for 循环结构 会在程序中使用 break 和 continue for 比 while 更简洁 什么是 for 循环 ... 语法: for 循环的语法和执行顺序 备注:2条 ...

  3. nodejs: 理解Buffer

    学习nodejs中buffer这一章,有一段写到buffer的拼接,其中一段源码非常优美,特拿来与大家共享. var chunks = []; var size = 0; res.on('data', ...

  4. React和ES6(二)ES6的类和ES7的property initializer

    React与ES6系列: React与ES6(一)开篇介绍 React和ES6(二)ES6的类和ES7的property initializer React与ES6(三)ES6类和方法绑定 React ...

  5. split(),preg_split()与explode()函数分析与介

    split(),preg_split()与explode()函数分析与介 发布时间:2013-06-01 18:32:45   来源:尔玉毕业设计   评论:0 点击:965 split()函数可以实 ...

  6. NodeJS Hello world

    #2 NodeJS Hello world 打开 https://nodejs.org/api/synopsis.html 将上述代码保存至D:\NODEJS\example.js 打开CMD窗口,定 ...

  7. 微软BI 之SSIS 系列 - 使用 Script Component Destination 和 ADO.NET 解析不规则文件并插入数据

    开篇介绍 这一篇文章是 微软BI 之SSIS 系列 - 带有 Header 和 Trailer 的不规则的平面文件输出处理技巧 的续篇,在上篇文章中介绍到了对于这种不规则文件输出的处理方式.比如下图中 ...

  8. 学习WPF——初识依赖项属性

    入门 首先创建一个依赖项属性 然后绑定父容器的DataContext到这个依赖项的实例 接着绑定子元素的属性到依赖项属性(注意Button的Content属性) 程序最终的运行结果:   说明 首先是 ...

  9. thinkphp支持大小写url地址访问,不产生下划线

    from:http://www.111cn.net/phper/thinkPhp/57748.htm 一.在配置文件中开启了thinkphp的大小写识别功能,使链接大小写都可以正常访问: ‘URL_C ...

  10. Linux:多文件编辑

    多文件编辑 1.使用vim编辑多个文件 编辑多个文件有两种形式,一种是在进入vim前使用的参数就是多个文件.另一种就是进入vim后再编辑其他的文件. 同时创建两个新文件并编辑 $ vim 1.txt ...