.Net微信網(wǎng)頁開發(fā)解決用戶在不同公眾號或在公眾號、移動應(yīng)用之間帳號統(tǒng)一問題
開發(fā)背景:
最近一段時間一直在做關(guān)于微信方面的網(wǎng)站應(yīng)用開發(fā),這段時間也收獲的不少關(guān)于微信開發(fā)方面的開發(fā)技能,接觸的比較多的主要有微信公眾號和微信網(wǎng)站app第三方登錄授權(quán),以及微信會員卡,優(yōu)惠券和掃描二位碼的功能,今天我主要想要總結(jié)的是微信公眾號登錄和網(wǎng)站app第三方應(yīng)用微信授權(quán)登錄這兩者之間獲取到的Openid關(guān)聯(lián)問題,實現(xiàn)兩邊登錄都是同一個賬號。
首先我們必須區(qū)別開來微信公眾平臺開發(fā)是指微信公眾號進行業(yè)務(wù)開發(fā)(https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1445241432),為網(wǎng)站微信登錄授權(quán)是需要在微信開發(fā)平臺中創(chuàng)建網(wǎng)站應(yīng)用來使用的(https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&lang=zh_CN),但是要想把微信公眾號于微信網(wǎng)站授權(quán)登錄獲取到的Oppenid關(guān)聯(lián)起來的話我們可以通過UnionID關(guān)聯(lián)起來。
微信開放平臺配置:
登錄進入微信開放平臺>進行微信公眾號綁定
微信開發(fā)平臺公眾賬號關(guān)聯(lián)的如下圖:
UnionID機制說明:
開發(fā)者可通過OpenID來獲取用戶基本信息。特別需要注意的是,如果開發(fā)者擁有多個移動應(yīng)用、網(wǎng)站應(yīng)用和公眾帳號,可通過獲取用戶基本信息中的unionid來區(qū)分用戶的唯一性,因為只要是同一個微信開放平臺帳號下的移動應(yīng)用、網(wǎng)站應(yīng)用和公眾帳號,用戶的unionid是唯一的。換句話說,同一用戶,對同一個微信開放平臺下的不同應(yīng)用,unionid是相同的。
獲取用戶基本信息(包括UnionID機制)開發(fā)者可通過OpenID來獲取用戶基本信息。請使用https協(xié)議。
接口調(diào)用請求說明 http請求方式: GET https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
微信公眾號微信登錄配置:
在基本配置中獲取微信公眾號的appid和appsecrect(一定是要自己公眾號的),白名單是你在本地調(diào)試的微信項目的時候需要添加的你本地的ip地址,不然獲取不到你想要的accsee_token
配置服務(wù)器地址(url):這里是你的項目與微信服務(wù)器通訊的地方,一定不能填錯,Token是你項目中的,將其復(fù)制到這里即可,消息加密解密密鑰是微信端隨機生成的
在微信公眾號設(shè)置設(shè)置對應(yīng)業(yè)務(wù)域名,js接口安全域名,以及網(wǎng)頁授權(quán)域名
代碼實現(xiàn):
用戶同意授權(quán)獲取對應(yīng)的授權(quán)碼code(注意:我這里使用的是微信公眾號的登錄授權(quán),假如你需要做網(wǎng)站授權(quán)的換一個api即可下面兩步都是一樣)
微信網(wǎng)站用戶同意授權(quán)獲取code的api:
第三方使用網(wǎng)站應(yīng)用授權(quán)登錄前請注意已獲取相應(yīng)網(wǎng)頁授權(quán)作用域(scope=snsapi_login),則可以通過在PC端打開以下鏈接: https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect 若提示“該鏈接無法訪問”,請檢查參數(shù)是否填寫錯誤,如redirect_uri的域名與審核時填寫的授權(quán)域名不一致或scope不為snsapi_login。
//授權(quán)入口 public ActionResult WxLogin() { //異步跳轉(zhuǎn)地址 var loginUrl = "http://" + Request.Url.Authority + Url.Action("WxRegisterAndLogin") ; return Redirect("https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appid + "&redirect_uri=" + Url.Encode(loginUrl) + "&response_type=code&scope=snsapi_userinfo&state=state#wechat_redirect"); }
通過通過code獲取網(wǎng)頁授權(quán)access_token和用戶唯一標(biāo)識Openid,最后拉取用戶信息(需要scope為snsapi_userinfo)
/// <summary> /// 微信登錄注冊(通過unionid來判斷之前是否已經(jīng)存在同一個工作平臺注冊過的賬號,假如存在的話則關(guān)聯(lián)起來,不存在注冊一個新的賬號) /// </summary> /// <param name="code">獲取用戶憑證換取用戶網(wǎng)頁授權(quán)</param> /// <param name="ReturnUrl">跳轉(zhuǎn)地址</param> /// <returns></returns> public async Task<ActionResult> WxRegisterAndLogin(string code, string ReturnUrl = "") { try { //登錄成功后跳轉(zhuǎn)的地址 string url=ReturnUrl; //通過Code以及微信appscrect和wxappid換取網(wǎng)頁授權(quán)access_token和用戶oppenid HttpClient webClient = new HttpClient(); var jsonString = await (await webClient.GetAsync("https://api.weixin.qq.com/sns/oauth2/access_token?appid=" +公眾號appid+ "&secret=" + 公眾號AppSecret + "&code=" + code + "&grant_type=authorization_code")).Content.ReadAsStringAsync(); //異步獲取的用戶oppenid和access_token var jsonOAuthorObj = JsonConvert.DeserializeObject(jsonString, new { access_token = "", openid = "" }.GetType()); if (jsonOAuthorObj.openid == null) { return Content(jsonString + "出現(xiàn)錯誤請重試"); } var myuser = new user { WxOpenId = jsonOAuthorObj.openid }.SelectObject(); //注冊成功后直接登錄,授權(quán)會判斷是否有賬戶 if (myuser == null) { //拉取用戶信息(需scope為 snsapi_userinfo),和unionid(只有在用戶將公眾號綁定到微信開放平臺帳號后,才會出現(xiàn)該字段) jsonString = await (await webClient.GetAsync("https://api.weixin.qq.com/sns/userinfo?access_token=" + jsonOAuthorObj.access_token + "&openid=" + jsonOAuthorObj.openid + "&lang=zh_CN")).Content.ReadAsStringAsync(); dynamic jsonObj = JsonConvert.DeserializeObject(jsonString, new { nickname = "", headimgurl = "", sex = "", openid = "", country = "", province = "", city = "",unionid=""}.GetType()); //查詢系統(tǒng)中是否存在unionid用戶信息,若存在則更新當(dāng)前用戶openid,并直接登錄,如果不存在的話則需要創(chuàng)建一個新的用戶信息 var isExistUserInfo=new user(){unionid=unionid }.SelectObject(); if(isExistUserInfo!=null)//存在該用戶記錄 { //更新公眾號openid isExistUserInfo.WxOpenId=jsonObj.openid; isExistUserInfo.Update(); //存在用戶信息直接登錄 return Redirect(url); } else//不存在該用戶記錄 { //創(chuàng)建用戶 int cUserId = new user { Wximage= jsonObj.headimgurl, WxNickName = jsonObj.nickname, WxOpenId = jsonObj.openid, Sex = Convert.ToInt32(jsonObj.sex), Country = jsonObj.country, Province = jsonObj.province, City = jsonObj.city,unionid=unionid }.Create(); return RedirectToAction("WxRegister", "Login", new { ReturnUrl = url }); } } else { //存在用戶信息直接登錄 return Redirect(url); } } catch (Exception e) { return View("MessageInfo", "", e.ToString()); } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ASP.NET 使用application與session對象寫的簡單聊天室程序
寫了快一年的asp.net,application對象還真沒怎么用過??戳丝磿?,根據(jù)這兩個對象的特性寫了一個簡單的聊天室程序。真的是非常的簡陋2014-07-07ASP.NET創(chuàng)建動態(tài)縮略圖的方法
這篇文章主要介紹了ASP.NET創(chuàng)建動態(tài)縮略圖的方法,實例分析了asp.net動態(tài)操作圖片的相關(guān)技巧,需要的朋友可以參考下2015-06-06