电驴搜索器,王快水库,石景山经济适用房
最近在做个微信公众号的项目,需要将入口放置在公众号二级菜单内,通过点击该菜单链接后进入到该项目中去,进入到项目后程序会自动通过微信公众号的api完成用户的openid获取。需求很简单,实现起来也不复杂,于是在一番折腾后需求实现了。为此,写下此文仅为初次接触的朋友提供个小小的帮助。
准备
老规矩,在开始动手前,咱们先简单介绍下实现的组成部分,如下:
微信公众号静默获取用户openid:要实现该功能,可以通过微信公众号提供的“网页授权”接口完成(官网描述:以snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的。用户感知的就是直接进入了回调页(往往是业务页面)),具体说明在此:
lezhima.site:是一个基于asp.net core2的web mvc带视图的程序,用来模拟接受微信公众号菜单链接的请求,并自动获取用户的openid。
准备
如上面所述,我们已经清楚了整个实现思路,那么下面就来看看lezhima.site项目内的代码实现吧:
1、首先我们先创建一个名为“basiccontroller”的业务基类,并继承“controller”类。其作用有两个,一是将验证是否正确获取openid的业务封装成基类,二是方便其它业务控制器使用openid。具体代码如下:
1 /// <summary> 2 /// 业务基类 3 /// </summary> 4 public class basiccontroller:controller 5 { 6 //当前用户openid 7 protected string currentuseropenid { set; get; } 8 9 public basiccontroller() 10 { 11 //从cookie中获取当前用户的openid 12 var cookie = cookies.getcookiebyuser(); 13 //如果没有,则导航到指定提示页,需要用户关闭后重新进入 14 if (string.isnullorempty(cookie)) 15 { 16 system.web.httpcontext.current.response.redirect("/vxinweb/index"); 17 return; 18 } 19 20 currentuseropenid = cookie; 21 } 22 }
2、再创建一个名为“vxinwebcontroller”的控制器与view视图。其作用是用来接受来自微信公众号菜单内的链接入口,并自动完成获取用户openid。代码如下:
1 /// <summary> 2 /// 此页面用于对外微信菜单地址,用于获取用户openid 3 /// 这是本系统网页的入口 4 /// </summary> 5 public class vxinwebcontroller : controller 6 { 7 public actionresult index() 8 { 9 //获取当前进到本系统的微信用户的openid 10 //该请求从微信那边过来 11 if (request.querystring["code"] != null) 12 { 13 var code = request.querystring["code"].tostring(); 14 var openid = vxinutils.getopenid(code); 15 if (openid == null)//没有获取到openid 16 { 17 //返回当前视图,需要提示用户关闭窗口,尝试重新进入 18 return view(); 19 } 20 //将openid放入cookie,放到cookie之前需将openid进行加密,取出来后再解密 21 cookies.setusertocookie(openid); 22 return redirecttoaction("index", "home"); 23 } 24 return view(); 25 } 26 }
3、在第二步时,我们发现有个vxinutils类,该类封装了对微信公众号api的操作,具体代码如下:
1 /// <summary> 2 /// 微信公众号工具类 3 /// </summary> 4 public class vxinutils 5 { 6 7 /// <summary> 8 /// 微信token 9 /// </summary> 10 public static string weixintoken { get { return configurationmanager.appsettings["weixintoken"].tostring(); } } 11 12 /// <summary> 13 /// 微信appid 14 /// </summary> 15 public static string appid { get { return configurationmanager.appsettings["appid"].tostring(); } } 16 17 18 /// <summary> 19 /// 微信aappsecret 20 /// </summary> 21 public static string appsecret { get { return configurationmanager.appsettings["appsecret"].tostring(); } } 22 23 24 /// <summary> 25 /// 获得access_token地址 26 /// </summary> 27 public static string access_token_url { get { return string.format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", appid, appsecret); } } 28 29 /// <summary> 30 /// 通过code换取网页授权access_token地址 31 /// </summary> 32 public static string web_access_token_url { get { return string.format("https://api.weixin.qq.com/sns/oauth2/access_token?appid={0}&secret={1}&grant_type=authorization_code&code=", appid, appsecret); } } 33 34 35 /// <summary> 36 /// 微信菜单创建提交地址 37 /// </summary> 38 public static string menu_post_url { get { return "https://api.weixin.qq.com/cgi-bin/menu/create?access_token="; } } 39 40 41 /// <summary> 42 /// 微信获取用户分组地址 43 /// </summary> 44 public static string group_get_url { get { return "https://api.weixin.qq.com/cgi-bin/groups/get?access_token="; } } 45 46 47 /// <summary> 48 /// 微信修改用户分组地址 49 /// </summary> 50 public static string group_update_url { get { return "https://api.weixin.qq.com/cgi-bin/groups/members/update?access_token="; } } 51 52 53 54 /// <summary> 55 /// 微信获取用户所属分组地址 56 /// </summary> 57 public static string group_getusergroup_url { get { return "https://api.weixin.qq.com/cgi-bin/groups/getid?access_token="; } } 58 59 /// <summary> 60 /// 拉取用户信息(需scope为 snsapi_userinfo) 61 /// 如果网页授权作用域为snsapi_userinfo,则此时开发者可以通过access_token和openid拉取用户信息了。 62 /// https://api.weixin.qq.com/sns/userinfo?access_token=access_token&openid=openid&lang=zh_cn 63 /// </summary> 64 public static string getuseruserinfo_url { get { return "https://api.weixin.qq.com/sns/userinfo?lang=zh_cn&access_token="; } } 65 66 67 /// <summary> 68 /// 获取用户的openid 69 /// </summary> 70 /// <param name="code"></param> 71 /// <returns></returns> 72 public static string getopenid(string code) 73 { 74 var openid = ""; 75 using (var wl = new webclient()) 76 { 77 wl.headers.add(httprequestheader.accept, "json"); 78 wl.headers.add(httprequestheader.contenttype, "application/json;charset=utf-8"); 79 wl.headers.add(httprequestheader.useragent, "mozilla/4.0"); 80 wl.encoding = encoding.utf8; 81 openid = wl.downloadstring(web_access_token_url + code); 82 } 83 if (!string.isnullorempty(openid)) 84 { 85 var token = jobject.parse(openid).selecttoken("openid"); 86 if (token != null) 87 openid = token.tostring(); 88 } 89 return openid; 90 } 91 92 }
总结
1、基于“snsapi_base为scope发起的网页授权”的微信公众号方案,可以很方便的实现用户静默授权及获取用户的openid。
2、通过将获取到的openid写入在cookie中,并封装一个业务基类完成cookie的读取与判断,可以使其它业务类很方便的使用openid。
声明
本文为作者原创,转载请备注出处与保留原文地址,谢谢。如文章能给您带来帮助,请点下推荐或关注,感谢您的支持!
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Blazor server side 自家的一些开源的, 实用型项目的进度之 CEF客户端
.NET IoC模式依赖反转(DIP)、控制反转(Ioc)、依赖注入(DI)
vue+.netcore可支持业务代码扩展的开发框架 VOL.Vue 2.0版本发布
网友评论