## 賬戶授權相關
~~~
關于UnionID機制
1、請注意,網頁授權獲取用戶基本信息也遵循UnionID機制。即如果開發者有在多個公眾號,或在公眾號、移動應用之間統一用戶帳號的需求,需要前往微信開放平臺(open.weixin.qq.com)綁定公眾號后,才可利用UnionID機制來滿足上述需求。
2、UnionID機制的作用說明:如果開發者擁有多個移動應用、網站應用和公眾帳號,可通過獲取用戶基本信息中的unionid來區分用戶的唯一性,因為同一用戶,對同一個微信開放平臺下的不同應用(移動應用、網站應用和公眾帳號),unionid是相同的。
https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842
~~~
~~~
關于網頁授權access_token和普通access_token的區別
1、微信網頁授權是通過OAuth2.0機制實現的,在用戶授權給公眾號后,公眾號可以獲取到一個網頁授權特有的接口調用憑證(網頁授權access_token),通過網頁授權access_token可以進行授權后接口調用,如獲取用戶基本信息;(web_access_token)
2、其他微信接口,需要通過基礎支持中的“獲取access_token”接口來獲取到的普通access_token調用。(common_access_token)
~~~
* * * * *
### 有兩個可獲取用戶信息的接口
#### 一:網頁授權時獲取用戶信息
```
https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
```
> 用web_access_token,不能獲取到subscribe;沒有單獨獲取網頁授權access_token的接口,通過code獲取openid的同時也獲取到了access_token
文檔:[第四步:拉取用戶信息(需scope為 snsapi_userinfo)](https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842)
* * * * *
#### 二:通過普通access_token獲取用戶信息
```
https://api.weixin.qq.com/cgi-bin/user/info?access_token={$commonAccessToken}&openid={$openid}&lang=zh_CN
```
> 用commonAccessToken,能獲取到subscribe,獲取看看用戶是否關注了 你的微信公眾號, 再來判斷是否提示用戶 關注(access_token為普通access_token而非網頁授權的access_token)
文檔:[獲取用戶基本信息(UnionID機制)](https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140839)
[獲取access_token](https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183)
> 建議公眾號開發者使用中控服務器統一獲取和刷新Access_token,其他業務邏輯服務器所使用的access_token均來自于該中控服務器,不應該各自去刷新,否則容易造成沖突,導致access_token覆蓋而影響業務;
* * * * *
#### 分析:
>[info] subscribe:用戶是否訂閱該公眾號標識,值為0時,代表此用戶沒有關注該公眾號,拉取不到其余信息,只有openid和UnionID(在該公眾號綁定到了微信開放平臺賬號時才有)。
看來兩個接口需要聯合使用,接口1不能獲得關注狀態,接口2能獲取關注狀態,但不一定能得到用戶其它信息。
接口1使用網頁授權access_token,接口2使用普通access_token,這個要注意。
另外關于緩存access_token,普通access_token直接返回,和每個APPID對應的,直接緩存即可;而網頁授權access_token則是用code換取的(同時得到網頁授權access_token和OpenID),如果要緩存,**只能根據用戶來緩存access_token,因為每個用戶的access_token不一樣。**
<span style="color: red;font-weight: bolder;">那這樣由此就有兩種了,用戶授權訪問令牌(web_access_token),應用授權令牌(common_access_token)。</span>
Q:每次授權登陸時都要獲取openID,同時也一并獲取到了access_token,那這樣還有必要緩存這個網頁授權access_token嗎?
A:有必要,有時用戶已經在登陸態了,需要更新用戶信息(拉取用戶微信賬號信息),用接口1,那么此時不必再獲取一次授權吧,如果緩存的用戶access_token沒有到期,就可以直接使用了。
access_token 是跟 openid 一起返回的,通過code獲取的,那么緩存access_token有什么意義呢?每個用戶授權登錄都會通過code,獲取access_token和openid啊!
Q:普通access_token是每個appid一個,網頁授權access_token難道是每個用戶一個?
A:是,每個用戶的網頁授權access_token都不一樣,是獨立的,需要根據用戶獨立緩存。
* * * * *
TODO:關注時就能獲得openid,根據openid獲取用戶信息,給用戶注冊賬號?
* * * * *
### 擴展
[微信網頁授權access_token每個用戶都不一樣嗎?-CSDN論壇](https://bbs.csdn.net/topics/391928388)
[微信網頁授權的access_token需要緩存嗎? - guoshaomin的回答 - SegmentFault 思否](https://segmentfault.com/q/1010000006852721/a-1020000006870300)
[微信開發——網頁授權access_token與全局access_token獲取用戶信息的接口 - CSDN博客](https://blog.csdn.net/weixin_39735923/article/details/79202563)
* * * * *
last update:2018-5-29 15:53:14
- 開始
- 公益
- 更好的使用看云
- 推薦書單
- 優秀資源整理
- 技術文章寫作規范
- SublimeText - 編碼利器
- PSR-0/PSR-4命名標準
- php的多進程實驗分析
- 高級PHP
- 進程
- 信號
- 事件
- IO模型
- 同步、異步
- socket
- Swoole
- PHP擴展
- Composer
- easyswoole
- php多線程
- 守護程序
- 文件鎖
- s-socket
- aphp
- 隊列&并發
- 隊列
- 講個故事
- 如何最大效率的問題
- 訪問式的web服務(一)
- 訪問式的web服務(二)
- 請求
- 瀏覽器訪問阻塞問題
- Swoole
- 你必須理解的計算機核心概念 - 碼農翻身
- CPU阿甘 - 碼農翻身
- 異步通知,那我要怎么通知你啊?
- 實時操作系統
- 深入實時 Linux
- Redis 實現隊列
- redis與隊列
- 定時-時鐘-阻塞
- 計算機的生命
- 多進程/多線程
- 進程通信
- 拜占庭將軍問題深入探討
- JAVA CAS原理深度分析
- 隊列的思考
- 走進并發的世界
- 鎖
- 事務筆記
- 并發問題帶來的后果
- 為什么說樂觀鎖是安全的
- 內存鎖與內存事務 - 劉小兵2014
- 加鎖還是不加鎖,這是一個問題 - 碼農翻身
- 編程世界的那把鎖 - 碼農翻身
- 如何保證萬無一失
- 傳統事務與柔性事務
- 大白話搞懂什么是同步/異步/阻塞/非阻塞
- redis實現鎖
- 淺談mysql事務
- PHP異常
- php錯誤
- 文件加載
- 路由與偽靜態
- URL模式之分析
- 字符串處理
- 正則表達式
- 數組合并與+
- 文件上傳
- 常用驗證與過濾
- 記錄
- 趣圖
- foreach需要注意的問題
- Discuz!筆記
- 程序設計思維
- 抽象與具體
- 配置
- 關于如何學習的思考
- 編程思維
- 談編程
- 如何安全的修改對象
- 臨時
- 臨時筆記
- 透過問題看本質
- 程序后門
- 邊界檢查
- session
- 安全
- 王垠
- 第三方數據接口
- 驗證碼問題
- 還是少不了虛擬機
- 程序員如何談戀愛
- 程序員為什么要一直改BUG,為什么不能一次性把代碼寫好?
- 碎碎念
- 算法
- 實用代碼
- 相對私密與絕對私密
- 學習目標
- 隨記
- 編程小知識
- foo
- 落盤
- URL編碼的思考
- 字符編碼
- Elasticsearch
- TCP-IP協議
- 碎碎念2
- Grafana
- EFK、ELK
- RPC
- 依賴注入
- 科目一
- 開發筆記
- 經緯度格式轉換
- php時區問題
- 解決本地開發時調用遠程AIP跨域問題
- 后期靜態綁定
- 談tp的跳轉提示頁面
- 無限分類問題
- 生成微縮圖
- MVC名詞
- MVC架構
- 也許模塊不是唯一的答案
- 哈希算法
- 開發后臺
- 軟件設計架構
- mysql表字段設計
- 上傳表如何設計
- 二開心得
- awesomes-tables
- 安全的代碼部署
- 微信開發筆記
- 賬戶授權相關
- 小程序獲取是否關注其公眾號
- 支付相關
- 提交訂單
- 微信支付筆記
- 支付接口筆記
- 支付中心開發
- 下單與支付
- 支付流程設計
- 訂單與支付設計
- 敏感操作驗證
- 排序設計
- 代碼的運行環境
- 搜索關鍵字的顯示處理
- 接口異步更新ip信息
- 圖片處理
- 項目搭建
- 閱讀文檔的新方式
- mysql_insert_id并發問題思考
- 行鎖注意事項
- 細節注意
- 如何處理用戶的輸入
- 不可見的字符
- 抽獎
- 時間處理
- 應用開發實戰
- python 學習記錄
- Scrapy 教程
- Playwright 教程
- stealth.min.js
- Selenium 教程
- requests 教程
- pyautogui 教程
- Flask 教程
- PyInstaller 教程
- 蜘蛛
- python 文檔相似度驗證
- thinkphp5.0數據庫與模型的研究
- workerman進程管理
- workerman網絡分析
- java學習記錄
- docker
- 筆記
- kubernetes
- Kubernetes
- PaddlePaddle
- composer
- oneinstack
- 人工智能 AI
- 京東
- pc_detailpage_wareBusiness
- doc
- 電商網站設計
- iwebshop
- 商品規格分析
- 商品屬性分析
- tpshop
- 商品規格分析
- 商品屬性分析
- 電商表設計
- 設計記錄
- 優惠券
- 生成唯一訂單號
- 購物車技術
- 分類與類型
- 微信登錄與綁定
- 京東到家庫存系統架構設計
- crmeb
- 命名規范
- Nginx https配置
- 關于人工智能
- 從人的思考方式到二叉樹
- 架構
- 今日有感
- 文章保存
- 安全背后: 瀏覽器是如何校驗證書的
- 避不開的分布式事務
- devops自動化運維、部署、測試的最后一公里 —— ApiFox 云時代的接口管理工具
- 找到自己今生要做的事
- 自動化生活
- 開源與漿果
- Apifox: API 接口自動化測試指南