>本文已更新(11.05.2017),以反映對Auth0 API的更改。確保單頁應用程序(SPA)可能具有挑戰性。 水療通常由單獨的前端(例如AngularJS)和後端數據API組成。傳統的基於會話的身份驗證不適合此體系結構,因為它將狀態引入API,違反了REST原則並阻礙移動應用程序集成。
>這種方法的關鍵優勢:
>JWTS是AngularJS身份驗證的理想選擇。 通過將用戶的JWT存儲在本地存儲中,並將其包括在HTTP請求的授權標題中,可以訪問安全的API端點。 無效或丟失的JWT導致訪問拒絕。
超過基本身份驗證,強大的AngularJS實現需要:基於JWT有效性。
>條件渲染:show/hide元素(登錄/註銷按鈕)。
路線保護:防止未經身份驗證的用戶訪問特定路線。
UI更新:
yourcompany.auth0.com
>
http://localhost:8080
apis>使用啟動服務器。配置和
集成了auth0。 用您的auth0憑據替換佔位符值:
bower install
<code class="language-bash">npm install -g http-server</code>文件處理身份驗證後解析哈希:
http-server
app.js
(圖片:angularjs登錄頁面)index.html
<code class="language-javascript">// app.js (snippet) angularAuth0Provider.init({ clientID: AUTH0_CLIENT_ID, domain: AUTH0_DOMAIN, responseType: 'token id_token', redirectUri: AUTH0_CALLBACK_URL, audience: AUTH0_API_AUDIENCE, });</code>
(圖片:angularjs登錄狀態)app.run.js
>
<code class="language-javascript">// app.run.js (snippet) authService.handleParseHash();</code>
(圖像:angularJS註銷狀態)
>主頁創建
文件提供了一個帶有登錄/註銷按鈕和API調用按鈕的簡單UI。 文件使用>:>處理API調用
> authentication Service()
>
home.html
此服務處理登錄,註銷和身份驗證狀態管理:home.controller.js
$http
<code class="language-javascript">// home.controller.js (snippet) vm.getSecretMessage = function() { $http.get('http://localhost:3001/api/private', { headers: { Authorization: 'Bearer ' + localStorage.getItem('access_token') } }) .then(...) .catch(...); };</code>
使用express,auth.service.js
,和
>創建nodejs服務器
<code class="language-javascript">// auth.service.js (snippet) function authService($state, angularAuth0, authManager) { // ... login, handleParseHash, logout, isAuthenticated functions ... }</code>>使用
啟動服務器。 AngularJS應用程序現在可以向受保護的API端點提出請求。 >進一步的考慮和常見問題
>本文以其他Auth0功能(SSO,無密碼登錄,MFA)和其他支持的後端和移動SDK的方式結束。 一個全面的常見問題解答部分解決了有關社交登錄,會話管理,路線安全性,刷新,錯誤處理,自定義,多因素身份驗證,掛鉤,測試和調試的常見問題。 切記用實際的auth0值替換{YOUR-AUTH0-DOMAIN}
和{YOUR-AUTH0-API-AUDIENCE}
的佔位符。
以上是Auth0的Easy AngularJS身份驗證的詳細內容。更多資訊請關注PHP中文網其他相關文章!