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

nodejs微信開發(fā)之授權(quán)登錄+獲取用戶信息

 更新時(shí)間:2019年03月17日 15:10:51   作者:xiadd  
這篇文章主要介紹了nodejs微信開發(fā)之授權(quán)登錄+獲取用戶信息,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

上一篇:獲取access_token+自定義菜單

這部分代碼是之前就已經(jīng)完成了,但是考慮篇幅的問(wèn)題就和上篇分開了,這部分相較前面的方式較為復(fù)雜一點(diǎn),但是也是很容易理解的。

這里簡(jiǎn)單介紹一下微信網(wǎng)頁(yè)授權(quán)。

微信網(wǎng)頁(yè)授權(quán)配置回調(diào)域名:

注:下面引自官方文檔

1、在微信公眾號(hào)請(qǐng)求用戶網(wǎng)頁(yè)授權(quán)之前,開發(fā)者需要先到公眾平臺(tái)官網(wǎng)中的“開發(fā) - 接口權(quán)限 - 網(wǎng)頁(yè)服務(wù) - 網(wǎng)頁(yè)帳號(hào) - 網(wǎng)頁(yè)授權(quán)獲取用戶基本信息”的配置選項(xiàng)中,修改授權(quán)回調(diào)域名。請(qǐng)注意,這里填寫的是域名(是一個(gè)字符串),而不是URL,因此請(qǐng)勿加 http:// 等協(xié)議頭;

2、授權(quán)回調(diào)域名配置規(guī)范為全域名,比如需要網(wǎng)頁(yè)授權(quán)的域名為:www.qq.com,配置以后此域名下面的頁(yè)面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以進(jìn)行OAuth2.0鑒權(quán)。但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com無(wú)法進(jìn)行OAuth2.0鑒權(quán)。

比如:需要授權(quán)的網(wǎng)頁(yè)域名為http://xiadd.weixin.qq.com/demo,那么需要配置回調(diào)域名為xiadd.weixin.qq.com。其他域名同理。配置圖示如下:

在權(quán)限里找到這部分,點(diǎn)擊修改。


將回調(diào)域名改為自己需要的域名:


這樣回調(diào)域名就修改成功了。

授權(quán)登錄

關(guān)于授權(quán)登錄的各種參數(shù)細(xì)節(jié)這里就不多說(shuō)了,但是這里也有一個(gè)access_token需要注意一下,和全局緩存的那個(gè)注意不要搞混了(話說(shuō)tx為啥不做一下命名區(qū)分)。這里的access_token是oauth的一個(gè)憑證,全局緩存的那個(gè)是調(diào)用微信公眾平臺(tái)各個(gè)基礎(chǔ)接口所要用到的憑證。
具體而言,網(wǎng)頁(yè)授權(quán)流程分為四步:
1、引導(dǎo)用戶進(jìn)入授權(quán)頁(yè)面同意授權(quán),獲取code
2、通過(guò)code換取網(wǎng)頁(yè)授權(quán)access_token(與基礎(chǔ)支持中的access_token不同)
3、如果需要,開發(fā)者可以刷新網(wǎng)頁(yè)授權(quán)access_token,避免過(guò)期
4、通過(guò)網(wǎng)頁(yè)授權(quán)access_token和openid獲取用戶基本信息
這里的第三步不是必須的,這里先不提,也就是授權(quán)登錄主要是三部分。引導(dǎo)用戶點(diǎn)擊相應(yīng)鏈接獲取code,code換區(qū)access_token,通過(guò)access_token去的相應(yīng)信息。

引導(dǎo)用戶獲取code

因?yàn)槭跈?quán)登錄的權(quán)限較高,所以微信平臺(tái)會(huì)對(duì)鏈接的順序進(jìn)行校驗(yàn),順序是固定的。鏈接格式如下:
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect

其中appid是固定的,就是公眾號(hào)的appid。
redirect_uri就是授權(quán)成功后需要跳轉(zhuǎn)到的鏈接。
response_type是固定的就是code。
scope就是授權(quán)權(quán)限,主要有兩種:snsapi_base (不彈出授權(quán)頁(yè)面,直接跳轉(zhuǎn),只能獲取用戶openid),snsapi_userinfo (彈出授權(quán)頁(yè)面,可通過(guò)openid拿到昵稱、性別、所在地。并且,即使在未關(guān)注的情況下,只要用戶授權(quán),也能獲取其信息)。

這里的scope以snsapi_userinfo為例,獲取用戶的信息。點(diǎn)進(jìn)鏈接進(jìn)入到授權(quán)頁(yè)面。如圖:


授權(quán)后得到url形式如下。code就包含在url里:

這樣code就得到了。code只能使用一次,5分鐘未被使用自動(dòng)過(guò)期。

通過(guò)code換取網(wǎng)頁(yè)授權(quán)access_token

再次提醒,這里的access_token和全局緩存的access_token是不一樣的。具體返回參數(shù)請(qǐng)看文檔,這里不一一列出了。
得到code后,通過(guò)get請(qǐng)求https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code,參數(shù)分別為appid,appsecret,和前一步獲取的code,雖然這里可以通過(guò)瀏覽器進(jìn)行請(qǐng)求,但是因?yàn)榘踩?jí)別高,所以千萬(wàn)在服務(wù)端進(jìn)行請(qǐng)求。代碼如下:

//getWebToken.js
function getToken(code) {
 let reqUrl = 'https://api.weixin.qq.com/sns/oauth2/access_token?';
 let params = {
 appid: config.appId,
 secret: config.appSecret,
 code: code,
 grant_type: 'authorization_code'
 };

 let options = {
 method: 'get',
 url: reqUrl+qs.stringify(params)
 };
 console.log(options.url);
 return new Promise((resolve, reject) => {
 request(options, function (err, res, body) {
  if (res) {
  resolve(body);
  } else {
  reject(err);
  }
 })
 })
}

就是很簡(jiǎn)單的一個(gè)請(qǐng)求得到想要的數(shù)據(jù)。但是注意得到的數(shù)據(jù)是個(gè)字符串,需要進(jìn)行處理,響應(yīng)格式如下:

對(duì)于scope為snsapi_base的授權(quán),這里是最后一步,會(huì)返回openid。如果需要再進(jìn)行下一步。

拉取用戶信息

如果網(wǎng)頁(yè)授權(quán)作用域?yàn)閟nsapi_userinfo,則此時(shí)開發(fā)者可以通過(guò)access_token和openid拉取用戶信息了。
請(qǐng)求方法
http:GET(請(qǐng)使用https協(xié)議) https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
這里也很簡(jiǎn)單。直接看代碼:

function getUserInfo(AccessToken, openId) {
 let reqUrl = 'https://api.weixin.qq.com/sns/userinfo?';
 let params = {
 access_token: AccessToken,
 openid: openId,
 lang: 'zh_CN'
 };

 let options = {
 method: 'get',
 url: reqUrl+qs.stringify(params)
 };
 
 return new Promise((resolve, reject) => {
 request(options, function (err, res, body) {
  if (res) {
  resolve(body);
  } else {
  reject(err);
  }
 });
 })
}

具體響應(yīng)到網(wǎng)頁(yè)上如圖所示:

這樣就通過(guò)授權(quán)登錄拉取到了用戶信息。

github地址奉上:https://github.com/xiadd/shorthand 歡迎star

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 配置node服務(wù)器并且鏈接微信公眾號(hào)接口配置步驟詳解

    配置node服務(wù)器并且鏈接微信公眾號(hào)接口配置步驟詳解

    這篇文章主要介紹了配置node服務(wù)器并且鏈接微信公眾號(hào)接口配置步驟詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下
    2019-06-06
  • Node.js實(shí)現(xiàn)修改文件字符集功能的具體過(guò)程

    Node.js實(shí)現(xiàn)修改文件字符集功能的具體過(guò)程

    在日常生活、工作中,我們經(jīng)常會(huì)遇到需要處理不同編碼格式的文件,有時(shí),在嘗試打開這些文件時(shí)會(huì)遇到亂碼,原因通常是文件的編碼與我們使用的文本編輯器或編程語(yǔ)言的默認(rèn)編碼不匹配,這篇文章將介紹Node.js修改文件字符集的實(shí)現(xiàn)思路和具體實(shí)現(xiàn)過(guò)程
    2024-08-08
  • Node.js前后端交互實(shí)現(xiàn)用戶登陸的實(shí)踐

    Node.js前后端交互實(shí)現(xiàn)用戶登陸的實(shí)踐

    本文主要介紹了Node.js前后端交互實(shí)現(xiàn)用戶登陸的實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • node高并發(fā)原理機(jī)制解讀

    node高并發(fā)原理機(jī)制解讀

    這篇文章主要介紹了node高并發(fā)原理機(jī)制,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • NodeJS遠(yuǎn)程代碼執(zhí)行

    NodeJS遠(yuǎn)程代碼執(zhí)行

    這篇文章主要介紹了NodeJS遠(yuǎn)程代碼執(zhí)行方法的相關(guān)資料,需要的朋友可以參考下
    2016-08-08
  • Node.js中DNS模塊學(xué)習(xí)總結(jié)

    Node.js中DNS模塊學(xué)習(xí)總結(jié)

    本篇文章給大家詳細(xì)介紹了Node.js中DNS模塊的相關(guān)知識(shí)點(diǎn),以及相關(guān)的實(shí)例代碼做了分享,有興趣的朋友參考下。
    2018-02-02
  • 在Node.js中使用Express實(shí)現(xiàn)視頻評(píng)論的列表展示和刪除功能

    在Node.js中使用Express實(shí)現(xiàn)視頻評(píng)論的列表展示和刪除功能

    在現(xiàn)代Web應(yīng)用中,視頻內(nèi)容和互動(dòng)功能(如評(píng)論)的結(jié)合極大地增加了用戶的參與度,本文將通過(guò)一個(gè)具體的例子,展示如何在Node.js環(huán)境中使用Express框架來(lái)實(shí)現(xiàn)視頻評(píng)論的列表展示和刪除功能,需要的朋友可以參考下
    2024-04-04
  • webpack打包、編譯、熱更新Node內(nèi)存不足問(wèn)題解決

    webpack打包、編譯、熱更新Node內(nèi)存不足問(wèn)題解決

    Webpack是現(xiàn)在主流的功能強(qiáng)大的模塊化打包工具,在使用Webpack時(shí),如果不注意性能優(yōu)化,有非常大的可能會(huì)產(chǎn)生性能問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于webpack打包、編譯、熱更新Node內(nèi)存不足問(wèn)題解決的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • 深入理解Node.js中的Worker線程

    深入理解Node.js中的Worker線程

    這篇文章主要介紹了深入理解Node.js中的Worker線程,對(duì)Worker線程感興趣的同學(xué),一定要看一下
    2021-04-04
  • 如何自定義node版本,實(shí)現(xiàn)node多版本控制方式

    如何自定義node版本,實(shí)現(xiàn)node多版本控制方式

    這篇文章主要介紹了如何自定義node版本,實(shí)現(xiàn)node多版本控制方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04

最新評(píng)論