接着上次的理论,我们这次来研究用代码实现“网页授权获取用户基本信息”,首先我们需要一个链接指向微信的授权页面,在微信开发平台中已经说了,这个链接必须在微信客户端中打开,那么我们就干脆使用文本消息来完成吧,也就是说当我们发送“授权”两个字的时候,微信给我们一个链接,我们点击这个链接然后进入“授权页面”。首先改造一下我们OnLoad函数:
- if (wx.MsgType == "text" && wx.Content == "你好")
- {
-
- res = sendTextMessage(wx, "你好,欢迎使用北京永杰友信科技有限公司公共微信平台!");
- }
- else if (wx.MsgType == "text" && wx.Content == "授权")
- {
- string MyAppid = "wx043225275885dafd";
- string RedirectUri = "http://wx.4ugood.net/OAuthRedirectUri.aspx";
- string URL = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + MyAppid + "&redirect_uri=" + RedirectUri + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect" ;
- string Str = "<a href=‘" + URL + "‘>授权页面</a>";
- res = sendTextMessage(wx, Str);
- }
- else if (wx.MsgType == "voice")
- {
- res = sendTextMessage(wx, wx.Recognition);
- }
- else if (wx.MsgType == "location")
- {
- res = sendTextMessage(wx, "您发送的位置是:" + wx.Label + ";纬度是:" + wx.Location_X + ";经度是:" + wx.Location_Y + ";缩放比例为:" + wx.Scale);
- }
- else
- {
- res = sendTextMessage(wx, "你好,未能识别消息!");
- }
其中,MyAppid不用说了,RedirectUri 是我们跳转后的网页,等会儿就会看到代码,URL是微信给出的格式,我们直接使用就OK了。这样就会反馈一个链接,点击就可以进入授权的页面了。
下面我们来看看RedirectUri参数的OAuthRedirectUri.aspx页面的源码吧,因为是讲解的例子,以说明问题为主,我就简化了其中也布局,OAuthRedirectUri.aspx.cs的内容如下:
首先我们用到了两个类:OAuth_Token和OAuthUser
然后是OAuthRedirectUri.aspx.cs的全部内容:
- public partial class OAuthRedirectUri : System.Web.UI.Page
- {
-
- string Appid = "wx043225275885dafd";
- string appsecret = "cb4425b24ab79ef875029cf0bf326ae9";
- protected void Page_Load(object sender, EventArgs e)
- {
- if (!IsPostBack)
- {
- if (!string.IsNullOrEmpty(Request.QueryString["code"]))
- {
- string Code = Request.QueryString["code"].ToString();
-
- OAuth_Token Model = Get_token(Code);
-
- OAuthUser OAuthUser_Model = Get_UserInfo(Model.access_token, Model.openid);
- Response.Write("用户OPENID:" + OAuthUser_Model.openid + "<br>用户昵称:" + OAuthUser_Model.nickname + "<br>性别:" + OAuthUser_Model.sex + "<br>所在省:" + OAuthUser_Model.province + "<br>所在市:" + OAuthUser_Model.city + "<br>所在国家:" + OAuthUser_Model.country + "<br>头像地址:" + OAuthUser_Model.headimgurl + "<br>用户特权信息:" + OAuthUser_Model.privilege);
-
- }
- }
- }
-
-
- protected OAuth_Token Get_token(string Code)
- {
- string Str = GetJson("https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + Appid + "&secret=" + appsecret + "&code=" + Code + "&grant_type=authorization_code");
- OAuth_Token Oauth_Token_Model = JsonHelper.ParseFromJson<OAuth_Token>(Str);
- return Oauth_Token_Model;
- }
-
- protected OAuth_Token refresh_token(string REFRESH_TOKEN)
- {
- string Str = GetJson("https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=" + Appid + "&grant_type=refresh_token&refresh_token=" + REFRESH_TOKEN);
- OAuth_Token Oauth_Token_Model = JsonHelper.ParseFromJson<OAuth_Token>(Str);
- return Oauth_Token_Model;
- }
-
- protected OAuthUser Get_UserInfo(string REFRESH_TOKEN, string OPENID)
- {
-
- string Str = GetJson("https://api.weixin.qq.com/sns/userinfo?access_token=" + REFRESH_TOKEN + "&openid=" + OPENID);
- OAuthUser OAuthUser_Model = JsonHelper.ParseFromJson<OAuthUser>(Str);
- return OAuthUser_Model;
- }
- protected string GetJson(string url)
- {
- WebClient wc = new WebClient();
- wc.Credentials = CredentialCache.DefaultCredentials;
- wc.Encoding = Encoding.UTF8;
- string returnText = wc.DownloadString(url);
-
- if (returnText.Contains("errcode"))
- {
-
- }
-
- return returnText;
- }
- }
其中用到的JsonHelper类在 《微信公共服务平台开发(.Net 的实现)5-------解决access_token过期的问题》 也提到过,不再粘贴了。这样我们就实现了授权到拉取用户信息的功能了。
微信公共服务平台开发(.Net 的实现)13-------网页授权(下 :C#代码的实现 )
原文:http://www.cnblogs.com/Alex80/p/4259200.html