本文实例讲述了C#实现的微信网页授权 *** 作逻辑封装。分享给大家供大家参考,具体如下:
一、微信网页授权登录
前提:
1.已经获取的接口权限,如果是测试账号就已经有权限了
2.配置接口的授权域名
更多说明可以参考方倍工作室:http://www.cnblogs.com/txw1958/p/weixin71-oauth20.HTML
或者官网API:http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.HTML
步骤:
1.用户同意授权,获取code
2.根据code 获取access_token及当前 *** 作用户的openID、unionID
3.根据openID获取用户基本信息(如果需要的话)
注:如果想在网站使用扫一扫,授权登录,可以讲 _oauth.GetCodeUrl() 授权地址生成二维码来使用
C#封装微信网页授权登录使用实例:
string appID = "wx145b4a8fd07b24e8";string appsecrect = "fe6951dcb99772411c42f724b1336065";string redirect_url = "配置域名下的回调地址";OAuthManage _oauth = null;/// <summary>///控制器构造函数/// </summary>public UserController(){ _oauth = new OAuthManage(appID,appsecrect,redirect_url);}/// <summary>/// 授权登录/// </summary>/// <returns></returns>public ActionResult AuthLogin(){ VIEwBag.url = _oauth.GetCodeUrl(); return VIEw();}/// <summary>/// 回调处理/// </summary>/// <returns></returns>public ActionResult OAuthHandle(){ string result = ""; //注册事件处理 _oauth.OnError = (e) => { string msg = ""; Exception inner = e; while (inner != null) { msg += inner.Message; inner = inner.InnerException; } result = msg; logoperate.Write(msg); }; _oauth.OnGetTokenSuccess = (token) => { result += "<br/>"; result += token.ToJsonString(); }; _oauth.OnGetUserInfoSuccess = (user) => { result += "<br/>"; result += user.ToJsonString(); }; //第二步 _oauth.GetAccess_Token(); //第三步 _oauth.GetUserInfo(); //显示结果 VIEwBag.msg = result; return VIEw();}
封装代码类定义:
namespace WXPackage{ /// <summary> /// 网页授权逻辑处理, /// 处理三步 *** 作,处理成功,返回用户基本信息 /// </summary> public class OAuthManage { #region 基本信息定义 /// <summary> /// 公众号的唯一标识 /// </summary> private string appID; /// <summary> /// 公众号的appsecret /// </summary> private string secret; /// <summary> /// 回调URL地址 /// </summary> private string redirect_uri; /// <summary> /// 获取微信用户基本信息使用snsAPI_userinfo模式 /// 如果使用静默授权,无法获取用户基本信息但可以获取到openID /// </summary> private string scope; public OAuthManage(string appID,string appsecret,string redirect_uri,bool IsUserInfo = true) { this.appID = appID; this.secret = appsecret; this.redirect_uri = redirect_uri; this.scope = IsUserInfo ? "snsAPI_userinfo" : "snsAPI_base"; } #endregion #region 请求过程信息 /// <summary> /// 第一步获取到的Code 值 /// </summary> public string Code { get; set; } /// <summary> /// 第二步获取到的access_token及相关数据 /// </summary> public OAuthAccess_Token TokenData = null; #endregion #region 事件定义 /// <summary> /// 当处理出现异常时,触发 /// </summary> public Action<Exception> OnError = null; /// <summary> /// 当获取Accesstoken成功是触发 /// </summary> public Action<OAuthAccess_Token> OnGetTokenSuccess = null; /// <summary> /// 当获取用户信息成功时触发 /// </summary> public Action<OAuthUser> OnGetUserInfoSuccess = null; #endregion #region 第二步,回调处理 /// <summary> /// 第二步,通过code换取网页授权access_token /// </summary> public voID GetAccess_Token() { try { //1.处理跳转 this.Code = ReqHelper.GetString("code"); if (string.IsNullOrEmpty(this.Code)) throw new Exception("获取code参数失败或用户禁止授权获取基本信息"); //1.发送获取access_token请求 string url = GetAccess_TokenUrl(); string result = NetHelper.Get(url); //2.解析相应结果 TokenData = JsonConvert.DeserializeObject<OAuthAccess_Token>(result); if (TokenData == null) throw new Exception("反序列化结果失败,返回内容为:" + result); //3.获取成功 if (OnGetTokenSuccess != null) OnGetTokenSuccess(TokenData); } catch (Exception ex) { Error("第二步,通过code换取网页授权access_token异常",ex); } } /// <summary> /// 刷新当前access_token /// </summary> public OAuthAccess_Token RefreshAccess_Token() { try { //1.发送请求 string url = GetReferesh_TokenUrl(); string result = NetHelper.Get(url); //2.解析结果 OAuthAccess_Token token = JsonConvert.DeserializeObject<OAuthAccess_Token>(result); if (token == null) throw new Exception("反序列化结果失败,返回内容:" + result); return token; } catch (Exception ex) { Error("刷新当前access_token失败",ex); return null; } } #endregion #region 第三步,获取用户基本信息 /// <summary> /// 第三步,获取基本信息 /// </summary> public voID GetUserInfo() { try { //1.发送get请求 string url = GetUserInfoUrl(); string result = NetHelper.Get(url); //2.解析结果 OAuthUser user = JsonConvert.DeserializeObject<OAuthUser>(result); if (user == null) throw new Exception("反序列化结果失败,返回内容:" + result); //3.获取成功 if (OnGetUserInfoSuccess != null) OnGetUserInfoSuccess(user); } catch (Exception ex) { Error("第三步、获取用户基本信息异常",ex); } } #endregion #region 静态方法 /// <summary> /// 验证授权凭证是否有效 /// </summary> /// <param name="access_token">access_token</param> /// <param name="openID">用户针对当前公众号的openID</param> /// <returns></returns> public static bool CheckWebAccess_Token(string access_token,string openID) { try { string url = string.Format("https://API.weixin.qq.com/sns/auth?access_token={0}&openID={1}",access_token,openID); string result = NetHelper.Get(url); JObject obj = JObject.Parse(result); int errcode = (int)obj["errcode"]; return errcode == 0; } catch (Exception ex) { throw new Exception("," + ex.Message); } } #endregion #region 获取请求连接 /// <summary> /// 获取Code的url 地址 /// </summary> /// <returns></returns> public string GetCodeUrl() { string url = string.Format("https://open.weixin.qq.com/connect/oauth2/authorize?appID={0}&redirect_uri={1}&response_type=code&scope={2}&state=STATE#wechat_redirect",this.appID,SecurityHelper.UrlEncode(this.redirect_uri),this.scope); return url; } /// <summary> /// 获取access_token的URL地址 /// </summary> /// <returns></returns> private string GetAccess_TokenUrl() { string url = string.Format("https://API.weixin.qq.com/sns/oauth2/access_token?appID={0}&secret={1}&code={2}&grant_type=authorization_code",this.secret,this.Code); return url; } /// <summary> /// 获取刷新Accesstoke的地址 /// </summary> /// <returns></returns> private string GetReferesh_TokenUrl() { string url = string.Format("https://API.weixin.qq.com/sns/oauth2/refresh_token?appID={0}&grant_type=refresh_token&refresh_token={1}",this.TokenData.refresh_token ); return url; } /// <summary> /// 获取用户基本信息地址 /// </summary> /// <returns></returns> private string GetUserInfoUrl() { string url = string.Format("https://API.weixin.qq.com/sns/userinfo?access_token={0}&openID={1}&lang=zh_CN",this.TokenData.access_token,this.TokenData.openID); return url; } #endregion private voID Error(string msg,Exception inner) { if (this.OnError != null) { this.OnError(new Exception(msg,inner)); } } } /// <summary> /// 授权之后获取用户基本信息 /// </summary> public class OAuthUser { 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; } /// <summary> /// 用户特权信息,Json 数组 /// </summary> public JArray privilege { get; set; } public string unionID { get; set; } } /// <summary> /// 获取Access_Token或者刷新返回的数据对象 /// </summary> public class OAuthAccess_Token { public string access_token { get; set; } public int expires_in { get; set; } public string refresh_token { get; set; } /// <summary> /// 用户针对当前公众号的唯一标识 /// 关注后会产生,返回公众号下页面也会产生 /// </summary> public string openID { get; set; } public string scope { get; set; } /// <summary> /// 当前用户的unionID,只有在用户将公众号绑定到微信开放平台帐号后 /// </summary> public string unionID { get; set; } }}
更多关于C#相关内容感兴趣的读者可查看本站专题:《C#常见控件用法教程》、《WinForm控件用法总结》、《C#数据结构与算法教程》、《C#面向对象程序设计入门教程》及《C#程序设计之线程使用技巧总结》
希望本文所述对大家C#程序设计有所帮助。
总结以上是内存溢出为你收集整理的C#实现的微信网页授权 *** 作逻辑封装示例全部内容,希望文章能够帮你解决C#实现的微信网页授权 *** 作逻辑封装示例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)