微信第三方平台处理授权公众号的网页授权接口

写一OAuthController的MVC控制器,用来接收公众号的网页授权请求

复制代码
 1 public async Task<ActionResult> RedirectCallback(string state, string code = "", string appid = "", string clienturl = "")
 2         {
 3             if (code.Length == 0)
 4             {
 5                 if (clienturl.IndexOf("?") != -1)
 6                     return Redirect(OAuthCallback + clienturl + "&errcode=-1&errmsg=" + HttpUtility.UrlEncode("用户禁止授权"));
 7                 else
 8                     return Redirect(OAuthCallback + clienturl + "?errcode=-1&errmsg=" + HttpUtility.UrlEncode("用户禁止授权"));
 9             }
10 
11             var ticketValue = "";
12             string path = AppDomain.CurrentDomain.SetupInformation.ApplicationBase + @"configs\WeChat.ThirdpartyPlatform.ComponentVerifyTicket.xml";
13             using (StreamReader sr = new StreamReader(path, Encoding.UTF8))
14             {
15                 string txt = sr.ReadToEnd();
16                 string[] lines = txt.Split("\r\n".ToCharArray(), StringSplitOptions.RemoveEmptyEntries);
17                 if (lines.Length == 4)
18                     ticketValue = lines[3];
19             }
20             var accessTokenValue = await Authentication.GetComponentAccessToken(AppId, AppSecret, ticketValue);
21             var jsonStr = await Util.HttpGetAsync("https://api.weixin.qq.com/sns/oauth2/component/access_token?appid=" + appid + "&code=" + code + "&grant_type=authorization_code&component_appid=" + AppId + "&component_access_token=" + accessTokenValue);
22             //if (jsonStr.Contains("errcode"))
23             //{
24             //    response.Content = new StringContent(jsonStr, Encoding.UTF8, "text/html");
25             //    return response;
26             //}
27             JObject result = Newtonsoft.Json.JsonConvert.DeserializeObject<JObject>(jsonStr);
28             string openid = result["openid"].Value<string>();
29             if (clienturl.IndexOf("?") != -1)
30                 return Redirect(OAuthCallback + clienturl + "&errcode=0&openid=" + openid);
31             else
32                 return Redirect(OAuthCallback + clienturl + "?errcode=0&openid=" + openid);
33         }
复制代码

 注意:由第三方平台授权的网页授权,不需要将“公众号设置->功能设置->网页授权域名”特地设置为返回url对应的域名。

 

posted @   妙衍软设  阅读(550)  评论(1编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示