前言
微信網頁授權共分為兩種方式:snsapi_base、snsapi_userinfo。 snsapi_base需關注公眾號,取得使用者資訊時不彈出使用者授權介面。 snsapi_userinfo是在使用者未追蹤公眾號的情況下瀏覽頁面,會先彈出一個使用者授權介面,使用者授權後才能拿到使用者資訊。這篇我們先看snsapi_base實作。
踩坑注意
剛開始我調試時snsapi_base方式,點擊頁面地址時提示地址連結不可用,網頁授權需要先在公眾號裡設定網頁基本訊息,也就是設定網域名稱。
區分清楚全域access_token與網頁授權access_token
看思路
1、透過回掉地址先拿到code。
2、透過code拿到openid。
3、透過appid和appsecret拿到全域access_token(這點區別於snsapi_userinfo)。 4、透過全域access_token和openid拿到使用者資訊。 看代碼 到這裡也就簡單了,主要是get方式調微信接口,同時準備好你的get和post請求方式,返回參數用json轉化成實體類。public ActionResult OAuthSnsApiBase() { string code = Request.QueryString["code"]; try { if (!string.IsNullOrEmpty(code)) { OAuthToken oauthToken = HttpUtility.Get<OAuthToken> (string.Format("https://api.weixin.qq.com/sns/oauth2/access_token?appid={0}&secret={1}&code={2}&grant_type=authorization_code", appID, appsecret, code)); string accesstoken = string.Empty; AccessToken token = HttpUtility.Get<AccessToken>(string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", appID,appsecret)); if (token != null && !string.IsNullOrEmpty(token.access_token)) { accesstoken = token.access_token; } if (oauthToken != null && !string.IsNullOrEmpty(oauthToken.openid)) { OAuthUserInfo userInfo = HttpUtility.Get<OAuthUserInfo>(string.Format("https://api.weixin.qq.com/cgi-bin/user/info?access_token={0}&openid={1}&lang=zh_CN", accesstoken, oauthToken.openid)); if (userInfo != null) { ViewData["headImage"] = userInfo.headimgurl; ViewData["openid"] = userInfo.openid; ViewData["nickName"] = userInfo.nickname; if (userInfo.sex == 0) { ViewData["sex"] = "未知"; } else if (userInfo.sex == 1) { ViewData["sex"] = "男"; } else { ViewData["sex"] = "女"; } ViewData["province"] = userInfo.province; ViewData["city"] = userInfo.city; } else { } } else { } } else { return Redirect(string.Format("https://open.weixin.qq.com/connect/oauth2/authorize?appid={0}&redirect_uri={1}&response_type=code&scope=snsapi_base&state=123456 #wechat_redirect", appID,"http://"+Request.Url.Host + Url.Action("OAuthSnsApiBase"))); } } catch (Exception ex) { ViewData["errmsg"] = ex.Message; } return View(); }
public class OAuthToken { public string access_token { get; set; } public int expires_in { get; set; } public string refresh_token { get; set; } public string openid { get; set; } public string scope { get; set; } } public class AccessToken { public string access_token { get; set; } public int expires_in { get; set; } }public class OAuthUserInfo { public string openid { get; set; } public string nickname { get; set; } public int sex { get; set; } public string province { get; set; } public string city { get; set; } public string country { get; set; } public string headimgurl { get; set; } public string privilege { get; set; } public string unionid { get; set; } }總結 這裡取得使用者資訊的介面是
https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID。和網頁授權二獲取使用者介面是不一樣的。
程式碼全部上傳到github裡:https://github.com/garfieldzf8/WeChat帶參考-user-info.html