javascript - 前后端分離的項目中如何使用微信授權登陸?
問題描述
我的想法是點擊登錄按鈕之后進入前端的一個登錄中轉頁面,這個中轉頁面的后端邏輯中通過code參數,向https://api.weixin.qq.com/sns...這個API獲取到用于訪問該用戶信息的access_token的同時在數據庫里面保存一個access_token與微信用戶openid的對應關系,并且向前端set一個值為該access_token的cookie。然后前端各種操作都帶上這個cookie,后端通過這個cookie找到對應的openid,并且通過服務端腳本上的app_secret,access_token等參數進行各種操作提交,然后完成操作。
我這個思路是否有什么不對的地方嘛?想問問各位在前后端分離項目中是如何做微信登陸授權的?
問題解答
回答1:第三方授權登陸的話。。。你得有自己的用戶系統吧。所以數據庫存的是openid,access_token和你用戶系統user_id的表。
前端的操作除非是需要訪問微信API的,需要帶上access_token,這時有兩種辦法,一種是把access_token寫到頁面上去,還有一種是用戶請求你的服務器的api,然后你服務器從數據庫取出access_token然后請求微信api。通常時使用后者的,因為一般的授權登陸的接口除了需要access_token以外,還會需要比方說appid和secret_code之類的,而secret_code通常是不能暴露的。
用戶的各種操作可以使用token來驗證,這個token是你用戶系統生成的token,這個token可以放到cookie中。
相關文章:
1. javascript - 請問 chrome 為什么會重復加載圖片資源?2. (python)關于如何做到按win+R再輸入文件文件名就可以運行?3. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處4. python - 能通過CAN控制一部普通的家用轎車嗎?5. javascript - react input file6. javascript - 請教如何獲取百度貼吧新增的兩個加密參數7. css3 - 微信前端頁面遇到的transition過渡動畫的bug8. Python爬蟲如何爬取span和span中間的內容并分別存入字典里?9. html5 - 只用CSS如何實現input框的寬度隨框里輸入的內容長短自動適應?10. javascript - 關于css絕對定位在ios瀏覽器被橡皮筋遮擋的問題
