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

前言

最近在做个微信公众号的项目,需要将入口放置在公众号二级菜单内,通过点击该菜单链接后进入到该项目中去,进入到项目后程序会自动通过微信公众号的API完成用户的OpenId获取。需求很简单,实现起来也不复杂,于是在一番折腾后需求实现了。为此,写下此文仅为初次接触的朋友提供个小小的帮助。

准备

老规矩,在开始动手前,咱们先简单介绍下实现的组成部分,如下:

微信公众号静默获取用户OpenId:要实现该功能,可以通过微信公众号提供的“网页授权”接口完成(官网描述:以snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的。用户感知的就是直接进入了回调页(往往是业务页面)),具体说明在此:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842

Lezhima.Site:是一个基于ASP.NET Core2的Web Mvc带视图的程序,用来模拟接受微信公众号菜单链接的请求,并自动获取用户的OpenId。

准备

如上面所述,我们已经清楚了整个实现思路,那么下面就来看看Lezhima.Site项目内的代码实现吧:

1、首先我们先创建一个名为“BasicController”的业务基类,并继承“Controller”类。其作用有两个,一是将验证是否正确获取OpenId的业务封装成基类,二是方便其它业务控制器使用OpenId。具体代码如下:

/// <summary>
/// 业务基类
/// </summary>
public class BasicController:Controller
{
	//当前用户openId
	protected string CurrentUserOpenId { set; get; }

	public BasicController()
	{
		//从Cookie中获取当前用户的openId
		var cookie = Cookies.GetCookieByUser();
		//如果没有,则导航到指定提示页,需要用户关闭后重新进入
		if (string.IsNullOrEmpty(cookie))
		{
			System.Web.HttpContext.Current.Response.Redirect("/VxinWeb/Index");
			return;
		}

		CurrentUserOpenId = cookie;
	}
}

2、再创建一个名为“VxinWebController”的控制器与View视图。其作用是用来接受来自微信公众号菜单内的链接入口,并自动完成获取用户OpenId。代码如下:

/// <summary>
/// 此页面用于对外微信菜单地址,用于获取用户openId
/// 这是本系统网页的入口
/// </summary>
public class VxinWebController : Controller
{
	public ActionResult Index()
	{
		//获取当前进到本系统的微信用户的openid
		//该请求从微信那边过来
		if (Request.QueryString["code"] != null)
		{
			var code = Request.QueryString["code"].ToString();
			var openId = VxinUtils.GetOpenID(code);
			if (openId == null)//没有获取到openId
			{
				//返回当前视图,需要提示用户关闭窗口,尝试重新进入
				return View();
			}
			//将openId放入cookie,放到cookie之前需将openId进行加密,取出来后再解密
			Cookies.SetUserToCookie(openId);
			return RedirectToAction("Index", "Home");
		}
		return View();
	}
}

3、在第二步时,我们发现有个VxinUtils类,该类封装了对微信公众号API的操作,具体代码如下:

/// <summary>
/// 微信公众号工具类
/// </summary>
public class VxinUtils
{

	/// <summary>
	/// 微信token
	/// </summary>
	public static string WeiXinToken { get { return ConfigurationManager.AppSettings["WeiXinToken"].ToString(); } }

	/// <summary>
	/// 微信appID
	/// </summary>
	public static string AppID { get { return ConfigurationManager.AppSettings["AppID"].ToString(); } }

	/// <summary>
	/// 微信Aappsecret
	/// </summary>
	public static string Appsecret { get { return ConfigurationManager.AppSettings["Appsecret"].ToString(); } }

	/// <summary>
	/// 获得access_token地址
	/// </summary>
	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); } }

	/// <summary>
	/// 通过code换取网页授权access_token地址
	/// </summary>
	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); } }

	/// <summary>
	/// 微信菜单创建提交地址
	/// </summary>
	public static string MENU_POST_URL { get { return "https://api.weixin.qq.com/cgi-bin/menu/create?access_token="; } }

	/// <summary>
	/// 微信获取用户分组地址
	/// </summary>
	public static string Group_Get_Url { get { return "https://api.weixin.qq.com/cgi-bin/groups/get?access_token="; } }

	/// <summary>
	/// 微信修改用户分组地址
	/// </summary>
	public static string Group_Update_Url { get { return "https://api.weixin.qq.com/cgi-bin/groups/members/update?access_token="; } }

	/// <summary>
	/// 微信获取用户所属分组地址
	/// </summary>
	public static string Group_GetUserGroup_Url { get { return "https://api.weixin.qq.com/cgi-bin/groups/getid?access_token="; } }

	/// <summary>
	/// 拉取用户信息(需scope为 snsapi_userinfo)
	/// 如果网页授权作用域为snsapi_userinfo,则此时开发者可以通过access_token和openid拉取用户信息了。
	/// https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
	/// </summary>
	public static string GetUserUserinfo_Url { get { return "https://api.weixin.qq.com/sns/userinfo?lang=zh_CN&access_token="; } }

	/// <summary>
	/// 获取用户的OpenId
	/// </summary>
	/// <param name="code"></param>
	/// <returns></returns>
	public static string GetOpenID(string code)
	{
		var openid = "";
		using (var wl = new WebClient())
		{
			wl.Headers.Add(HttpRequestHeader.Accept, "json");
			wl.Headers.Add(HttpRequestHeader.ContentType, "application/json;charset=UTF-8");
			wl.Headers.Add(HttpRequestHeader.UserAgent, "Mozilla/4.0");
			wl.Encoding = Encoding.UTF8;
			openid = wl.DownloadString(Web_Access_token_URL + code);
		}
		if (!string.IsNullOrEmpty(openid))
		{
			var token = JObject.Parse(openid).SelectToken("openid");
			if (token != null)
				openid = token.ToString();
		}
		return openid;
	}

}

总结

1、基于“snsapi_base为scope发起的网页授权”的微信公众号方案,可以很方便的实现用户静默授权及获取用户的OpenId。

2、通过将获取到的OpenId写入在Cookie中,并封装一个业务基类完成Cookie的读取与判断,可以使其它业务类很方便的使用OpenId。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • php判断用户是否关注微信公众号

    最近要做一个微信平台的投票活动,需要在关注公众号之后才能参与投票,那么,如何判断用户是否关注了公众号呢? 第一想法是,通过获取公众号的关注列表,然后搜索列表中是否有参与者的openid. 但是马上发现一个问题,就是这种方法需要每次都要获取一下关注列表,而且,当公众号的粉丝比较多时,这种方法就比较吃力了. 下面使用php方法,判断用户是否关注了公众号: <?php $access_token = "https://api.weixin.qq.com/cgi-bin/token?grant_t

  • .NET微信公众号获取OpenID和用户信息

    本文实例为大家分享了微信公众平台实现获取用户OpenID的方法,供大家参考,具体内容如下 Index.aspx.cs代码: public partial class Index : System.Web.UI.Page { //用户id public string openid = ""; //公众号信息部分 public string appid = ConfigurationManager.AppSettings["AppId"]; public string

  • 微信公众号用户与网站用户的绑定解决方案分析

    本文实例讲述了微信公众号用户与网站用户的绑定解决方案.分享给大家供大家参考,具体如下: 现在很多网站都已经建立了一套完整的用户账号体系,基于这套体系,再做其他应用的用户扩展就非常方便.例如,有了微软的outlook账户,就可以登录win8,可以登录微软的邮箱,还可以登录skype.同样地,一个Apple ID可以享受苹果的所有服务.正所谓,一个账号,处处使用. 对于企业,可能会有产品线通常有网站,app,微信公众号等.统一各产品线的账号体系,实现一个账号处处使用的目标是非常有必要的.网站和app

  • 微信公众号实现扫码获取微信用户信息(网页授权)

    刚开始接触微信的时候一头雾水,领导想要一个扫码获取微信用户信息的功能,而且是扫的别人的二维码,我是一阵忙活啊. 经过努力和尝试,终于功夫不负有心人啊,赶紧记录一下,我用的是thinkphp编写的. 第一步:就是二维码的生成  1.首先要确定第一个二维码,因为既然是扫码,肯定是要第一个二维码的,也就是第一人才可以.我将第一个二维码的唯一值(id)设置成零,然后开始我的编写 2.既然是二维码,我用了phpqrcode二维码生成插件,二维码的生成可以在本地编写,查看效果后再上传服务器. (1)从网上下

  • ASP.NET微信公众号之用户分组管理web页面

    本文实例为大家分享了ASP.NET微信用户分组管理的具体代码,供大家参考,具体内容如下 Model层实体类: public class UserList { public string total { get; set; } public string count { get; set; } public userlistopenid data { get; set; } public string next_openid { get; set; } } public class userlis

  • 微信公众号开发 自定义菜单跳转页面并获取用户信息实例详解

    微信公众号开发 自定义菜单 请先读完本文再进行配置开发 请先前往微信平台开发者文档阅读"网页授权获取用户基本信息"的接口说明 在微信公众账号开发中,往往有定义一个菜单,然后用户点击该菜单就进入用户个人中心的功能,通常应用于各个公众账号中的会员服务. 如何在微信自定义菜单中将用户导航到个人中心页面呢? 首选需要通过用户点击获取用户openid,而通过用户的点击跳转获取用户openid就必须在菜单中动态绑定用户的openid,或者在菜单的跳转URL中填写微信提供的链接,官方给了两个链接类型

  • 微信公众号支付(一)如何获取用户openId

    一.获取apikey,appsecret与商户号 注册公众号.商户号 二.获取用户的OpenId 1.设置[授权回调页面域名] 官方解释:用户在网页授权页同意授权给公众号后,微信会将授权数据传给一个回调页面,回调页面需在此域名下,以确保安全可靠.回调页面域名不支持IP地址. 2.用户同意授权 我是把这个url写在微信菜单下的,当进入这个页面的时候就让用户同意.注意:好像是静默授权的,用户不知道 1.url: https://open.weixin.qq.com/connect/oauth/aut

  • Java微信公众号开发之通过微信公众号获取用户信息

    最近由于公司业务,就开始研究微信开发的流程,说实话,这东西刚开始看到时候和看天书的一样,总算,看了一天的文档,测试代码终于出来了. 1.首先需要到微信网站去设置一下,我是直接用的微信测试号. 接口配置信息必须要填写的,所以说必须能将自己的服务发布出去 到此微信配置完毕,接下来就是直接上代码了 2.获取用户信息的方式一共是两种,前提都是用户关注微信公众号,一种是静默获取(snsapi_base,这种方式只能获取openid),另一种是授权获取(snsapi_userinfo,可以获取用户的详细信息

  • 微信公众号判断用户是否已关注php代码解析

    现在的活动,很多都引导用户关注公众号,才能参与到活动当中,那如何才能判断用户关注了公众号呢? 本文就为大家提供php代码,解决问题. 官方接口说明 获取用户基本信息(包括UnionID机制) http://mp.weixin.qq.com/wiki/14/bb5031008f1494a59c6f71fa0f319c66.html 1.只要有基础的access_token和用户openid就可以判断用户是否关注该公众号 2.利用的接口url为:https://api.weixin.qq.com/c

  • .NET微信公众号 用户分组管理

    本文实例为大家分享了.NET微信用户分组管理代码,供大家参考,具体内容如下 Model层实体类: public class UserList { public string total { get; set; } public string count { get; set; } public userlistopenid data { get; set; } public string next_openid { get; set; } } public class userlistopeni

  • 微信公众号-获取用户信息(网页授权获取)实现步骤

    根据微信公众号开发官方文档: 获取用户信息步骤如下: 1 第一步:用户同意授权,获取code 2 第二步:通过code换取网页授权access_token 3 第三步:刷新access_token(如果需要) 4 第四步:拉取用户信息(需scope为 snsapi_userinfo) 1 获取code 在确保微信公众账号拥有授权作用域(scope参数)的权限的前提下(服务号获得高级接口后,默认拥有scope参数中的snsapi_base和snsapi_userinfo),引导关注者打开如下页面:

随机推荐