亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ASP.NET Core2靜默獲取微信公眾號(hào)的用戶OpenId實(shí)例代碼

 更新時(shí)間:2018年12月05日 16:13:45   作者:Andre-Hub  
這篇文章主要給大家介紹了關(guān)于ASP.NET Core2靜默獲取微信公眾號(hào)的用戶OpenId的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

最近在做個(gè)微信公眾號(hào)的項(xiàng)目,需要將入口放置在公眾號(hào)二級(jí)菜單內(nèi),通過點(diǎn)擊該菜單鏈接后進(jìn)入到該項(xiàng)目中去,進(jìn)入到項(xiàng)目后程序會(huì)自動(dòng)通過微信公眾號(hào)的API完成用戶的OpenId獲取。需求很簡(jiǎn)單,實(shí)現(xiàn)起來也不復(fù)雜,于是在一番折騰后需求實(shí)現(xiàn)了。為此,寫下此文僅為初次接觸的朋友提供個(gè)小小的幫助。

準(zhǔn)備

老規(guī)矩,在開始動(dòng)手前,咱們先簡(jiǎn)單介紹下實(shí)現(xiàn)的組成部分,如下:

微信公眾號(hào)靜默獲取用戶OpenId:要實(shí)現(xiàn)該功能,可以通過微信公眾號(hào)提供的“網(wǎng)頁(yè)授權(quán)”接口完成(官網(wǎng)描述:以snsapi_base為scope發(fā)起的網(wǎng)頁(yè)授權(quán),是用來獲取進(jìn)入頁(yè)面的用戶的openid的,并且是靜默授權(quán)并自動(dòng)跳轉(zhuǎn)到回調(diào)頁(yè)的。用戶感知的就是直接進(jìn)入了回調(diào)頁(yè)(往往是業(yè)務(wù)頁(yè)面)),具體說明在此:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842

Lezhima.Site:是一個(gè)基于ASP.NET Core2的Web Mvc帶視圖的程序,用來模擬接受微信公眾號(hào)菜單鏈接的請(qǐng)求,并自動(dòng)獲取用戶的OpenId。

準(zhǔn)備

如上面所述,我們已經(jīng)清楚了整個(gè)實(shí)現(xiàn)思路,那么下面就來看看Lezhima.Site項(xiàng)目?jī)?nèi)的代碼實(shí)現(xiàn)吧:

1、首先我們先創(chuàng)建一個(gè)名為“BasicController”的業(yè)務(wù)基類,并繼承“Controller”類。其作用有兩個(gè),一是將驗(yàn)證是否正確獲取OpenId的業(yè)務(wù)封裝成基類,二是方便其它業(yè)務(wù)控制器使用OpenId。具體代碼如下:

/// <summary>
/// 業(yè)務(wù)基類
/// </summary>
public class BasicController:Controller
{
	//當(dāng)前用戶openId
	protected string CurrentUserOpenId { set; get; }

	public BasicController()
	{
		//從Cookie中獲取當(dāng)前用戶的openId
		var cookie = Cookies.GetCookieByUser();
		//如果沒有,則導(dǎo)航到指定提示頁(yè),需要用戶關(guān)閉后重新進(jìn)入
		if (string.IsNullOrEmpty(cookie))
		{
			System.Web.HttpContext.Current.Response.Redirect("/VxinWeb/Index");
			return;
		}

		CurrentUserOpenId = cookie;
	}
}

2、再創(chuàng)建一個(gè)名為“VxinWebController”的控制器與View視圖。其作用是用來接受來自微信公眾號(hào)菜單內(nèi)的鏈接入口,并自動(dòng)完成獲取用戶OpenId。代碼如下:

/// <summary>
/// 此頁(yè)面用于對(duì)外微信菜單地址,用于獲取用戶openId
/// 這是本系統(tǒng)網(wǎng)頁(yè)的入口
/// </summary>
public class VxinWebController : Controller
{
	public ActionResult Index()
	{
		//獲取當(dāng)前進(jìn)到本系統(tǒng)的微信用戶的openid
		//該請(qǐng)求從微信那邊過來
		if (Request.QueryString["code"] != null)
		{
			var code = Request.QueryString["code"].ToString();
			var openId = VxinUtils.GetOpenID(code);
			if (openId == null)//沒有獲取到openId
			{
				//返回當(dāng)前視圖,需要提示用戶關(guān)閉窗口,嘗試重新進(jìn)入
				return View();
			}
			//將openId放入cookie,放到cookie之前需將openId進(jìn)行加密,取出來后再解密
			Cookies.SetUserToCookie(openId);
			return RedirectToAction("Index", "Home");
		}
		return View();
	}
}

3、在第二步時(shí),我們發(fā)現(xiàn)有個(gè)VxinUtils類,該類封裝了對(duì)微信公眾號(hào)API的操作,具體代碼如下:

/// <summary>
/// 微信公眾號(hào)工具類
/// </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換取網(wǎng)頁(yè)授權(quán)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>
	/// 微信菜單創(chuàng)建提交地址
	/// </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)
	/// 如果網(wǎng)頁(yè)授權(quán)作用域?yàn)閟nsapi_userinfo,則此時(shí)開發(fā)者可以通過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;
	}

}

總結(jié)

1、基于“snsapi_base為scope發(fā)起的網(wǎng)頁(yè)授權(quán)”的微信公眾號(hào)方案,可以很方便的實(shí)現(xiàn)用戶靜默授權(quán)及獲取用戶的OpenId。

2、通過將獲取到的OpenId寫入在Cookie中,并封裝一個(gè)業(yè)務(wù)基類完成Cookie的讀取與判斷,可以使其它業(yè)務(wù)類很方便的使用OpenId。

好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

最新評(píng)論