当前位置: 移动技术网 > IT编程>开发语言>.net > ASP.NET Core2实现静默获取微信公众号的用户OpenId

ASP.NET Core2实现静默获取微信公众号的用户OpenId

2018年12月06日  | 移动技术网IT编程  | 我要评论

电驴搜索器,王快水库,石景山经济适用房

最近在做个微信公众号的项目,需要将入口放置在公众号二级菜单内,通过点击该菜单链接后进入到该项目中去,进入到项目后程序会自动通过微信公众号的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。

 

声明

本文为作者原创,转载请备注出处与保留原文地址,谢谢。如文章能给您带来帮助,请点下推荐或关注,感谢您的支持!

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网