前言
在 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來演示。
