前言
現在很多的桌面應用程式在登入時,會使用 OAuth2 ,所以在登入時,會開啟 Browser 到授權中心,讓使用者輸入帳/密後,再透過 Browser 來開啟 應用程式,如下,
Hello! 我是 RM
在 Native applications 因為是安裝在個人的設備上面,例如 手機,個人電腦。
這些 Native applications 通常會跟作業系統註冊 App-Claimed https URL (https://app.exp.com 會開啟該 application) 或是使用 Custom URL Scheme(myapp://callback#token=…)。
因為OAuth 2.0 - Implicit Flow可以用在 public client,
因為 Implicit Flow 比較不安全,所以現在大多改使用 PKCE,它是擴充自 Authorization Code Flow 。
在 OAuth 2.0 - Authorization Code Flow 在取得 Token 時,需要將 client_secret 一併傳出來取得 access token ,如果是 public client 就有可能會被知道 client_secret 的值,所以 PKCE 就是動態建立 Code Verifier 來取代 client_secret。
以下使用OAuth 2.0 Playground - pkce來演示。
在 OAuth 2.0 - Authorization Code Flow 了解它是先取回授權碼後再透過該授權碼,Client Id及Client Secret,再取回Access Token,透過它去存取 API。
Client Secret相當於是 Password,如果是 Public Client(SPA, Native applications),那就會讓別人知道Client Secret,
所以可以使用OAuth 2.0 - Implicit Flow
最近在 CentOS 8 上下載 NodeJS 的程式,然後下npm install
,就發生 npm ERR! sqlite3@4.2.0 install: node-pre-gyp install --fallback-to-build
的錯誤。
tag:
缺失模块。
1、请确保node版本大于6.2
2、在博客根目录(注意不是yilia根目录)执行以下命令:
npm i hexo-generator-json-content --save
3、在根目录_config.yml里添加配置:
jsonContent: meta: false pages: false posts: title: true date: true path: true text: false raw: false content: false slug: false updated: false comments: false link: false permalink: false excerpt: false categories: false tags: true