一、跳轉受權連接json
https://open.weixin.qq.com/connect/oauth2/authorize?appid=xxx&redirect_uri=xxx&response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirectapi
&connect_redirect=1 這個參數,剛開始沒有加,老是報 {'errcode':40029,'errmsg':'invalid code, hints: [ req_id: 0407ns44 ]'} 這個錯誤 ,調試時發現會訪問兩次,一次是301,頁面重定向了,第二次跟第一次就差這個參數。加上後,再也不報錯。code 能夠了。app
二須要注意的是 redirect_uri = xxx 須要本身URL轉碼spa
二、獲取用戶信息,直接上代碼。調試
<%@ WebHandler Language="C#" Class="getinfos" %> using System; using System.Web; using Newtonsoft.Json.Linq; using System.Net; using System.IO; using System.Text; public class getinfos : IHttpHandler { public void ProcessRequest (HttpContext context) { //一切都從這裏開始 string code = context.Request["code"].ToString(); context.Response.ContentType = "text/plain"; context.Response.Write(GetInfos(code)); } public bool IsReusable { get { return false; } } public string GetInfos(string _code) { // string _access_tokens = GetToken(_code); JObject json = JObject.Parse(_access_tokens); string access_token = json["access_token"].ToString(); string refresh_token = json["refresh_token"].ToString(); string openid = json["openid"].ToString(); // string _infos = GetUserInfo(access_token, openid); JObject info = JObject.Parse(_infos); if (info["errcode"] != null) { _access_tokens = RefreshToken(refresh_token); json = JObject.Parse(_access_tokens); access_token = json["access_token"].ToString(); openid = json["openid"].ToString(); _infos = GetUserInfo(access_token, openid); } return _infos; } /// <summary> /// 用code 獲取 Token /// </summary> private string GetToken(string _code) { if (_code.IndexOf("\"") > -1) _code = _code.Replace("\"", ""); string URL = "https://api.weixin.qq.com/sns/oauth2/access_token"; string RequestPara = "?appid=xxx"; RequestPara += "&secret=xxx"; RequestPara += "&code=" + _code; RequestPara += "&grant_type=authorization_code"; string _access_tokens = GetData(URL, RequestPara); _access_tokens = _access_tokens.Replace("\"", "'"); return _access_tokens; } /// <summary> /// 獲取用戶信息 /// </summary> private string GetUserInfo(string access_token, string openid) { if (access_token.IndexOf("\"") > -1) access_token = access_token.Replace("\"", ""); if (openid.IndexOf("\"") > -1) openid = openid.Replace("\"", ""); string I_URL = "https://api.weixin.qq.com/sns/userinfo"; string I_RequestPara = "?access_token=" + access_token; I_RequestPara += "&openid=" + openid; I_RequestPara += "&lang=zh_CN"; string _infos = GetData(I_URL, I_RequestPara); _infos = _infos.Replace("\"", "'"); return _infos; } /// <summary> /// 刷新 Token /// </summary> private string RefreshToken(string refresh_token) { if (refresh_token.IndexOf("\"") > -1) refresh_token = refresh_token.Replace("\"", ""); string R_URL = "https://api.weixin.qq.com/sns/oauth2/refresh_token"; string R_RequestPara = "?appid=xxx"; R_RequestPara += "&grant_type=refresh_token"; R_RequestPara += "&refresh_token=" + refresh_token; string _infos = GetData(R_URL, R_RequestPara); _infos = _infos.Replace("\"", "'"); return _infos; } /// <summary> /// 訪問地址,並獲取數據 /// </summary> private string GetData(string URL, string RequestPara) { RequestPara = RequestPara.IndexOf('?') > -1 ? (RequestPara) : ("?" + RequestPara); WebRequest hr = HttpWebRequest.Create(URL + RequestPara); byte[] buf = System.Text.Encoding.GetEncoding("utf-8").GetBytes(RequestPara); hr.Method = "GET"; System.Net.WebResponse response = hr.GetResponse(); StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.GetEncoding("utf-8")); string ReturnVal = reader.ReadToEnd(); reader.Close(); response.Close(); return ReturnVal; } }