using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net.Http;
using Codeplex.Data;
namespace LYFZ.Weixin.SDK
{
///
/// 对应微信API的 "用户管理"=> "网页授权获取用户基本信息”
/// http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html
///
public class OAuth2API
{
///
/// 第二步:通过code换取网页授权access_token
///
/// 第一步获取的code参数
/// 公众号的唯一标识
/// 公众号的appsecret
/// 正确时返回的JSON数据包如下:
///{
///"access_token":"ACCESS_TOKEN",
///"expires_in":7200,
///"refresh_token":"REFRESH_TOKEN",
///"openid":"OPENID",
///"scope":"SCOPE"
///}
///错误时微信会返回JSON数据包如下(示例为Code无效错误):
///{"errcode":40029,"errmsg":"invalid code"}
///
public static dynamic GetAccessToken(string code, string appId, string appSecret)
{
var client = new HttpClient();
var result = client.GetAsync(string.Format("https://api.weixin.qq.com/sns/oauth2/access_token?appid={0}&secret={1}&code={2}&grant_type=authorization_code", appId, appSecret, code)).Result;
if (!result.IsSuccessStatusCode) return null;
return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
}
///
/// 第三步:刷新access_token(如果需要)
/// 由于access_token拥有较短的有效期,当access_token超时后,可以使用refresh_token进行刷新,refresh_token拥有较长的有效期(7天、30天、60天、90天),当refresh_token失效的后,需要用户重新授权。
///
/// 填写通过access_token获取到的refresh_token参数
/// 公众号的唯一标识
///
/// 正确时返回的JSON数据包如下:
/// {
/// "access_token":"ACCESS_TOKEN",
/// "expires_in":7200,
/// "refresh_token":"REFRESH_TOKEN",
/// "openid":"OPENID",
/// "scope":"SCOPE"
/// }
///
/// 错误时微信会返回JSON数据包如下(示例为Code无效错误):
///{"errcode":40029,"errmsg":"invalid code"}
///
public static dynamic RefreshAccess_token(string refreshToken, string appId)
{
var client = new HttpClient();
var result = client.GetAsync(string.Format("https://api.weixin.qq.com/sns/oauth2/refresh_token?appid={0}&grant_type=refresh_token&refresh_token={1}", appId, refreshToken)).Result;
if (!result.IsSuccessStatusCode) return null;
return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
}
///
/// 第四步:拉取用户信息(需scope为 snsapi_userinfo)
///
/// 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
/// 用户的唯一标识
/// 返回国家地区语言版本,zh_CN 简体,zh_TW 繁体,en 英语
///
/// 正确时返回的JSON数据包如下:
/// {
/// "openid":" OPENID",
/// "nickname": NICKNAME,
/// "sex":"1",
/// "province":"PROVINCE"
/// "city":"CITY",
/// "country":"COUNTRY",
/// "headimgurl": "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/46",
///"privilege":[
///"PRIVILEGE1"
///"PRIVILEGE2"
/// ]
///}
///
///错误时微信会返回JSON数据包如下(示例为openid无效):
///{"errcode":40003,"errmsg":" invalid openid "}
///
public static dynamic GetUserInfo(string accessToekn, string openId, string lang = "zh_CN")
{
var client = new HttpClient();
var result = client.GetAsync(string.Format("https://api.weixin.qq.com/sns/userinfo?access_token={0}&openid={1}&lang={2}", accessToekn, openId, lang)).Result;
if (!result.IsSuccessStatusCode) return null;
return DynamicJson.Parse(result.Content.ReadAsStringAsync().Result);
}
}
}