隨著互聯網的不斷發展,越來越多的網站采用授權登錄的方式,使用戶可以通過其他網站的賬戶信息進行登錄。這不僅方便了用戶的使用,同時也提升了網站的用戶數量和用戶黏性。Vue 作為一種流行的前端框架,同樣可以實現授權登錄功能,本文將介紹如何使用 Vue 引入授權登錄。
首先,我們需要選擇第三方登錄服務提供商。著名的服務提供商有 Facebook,Google,Twitter 等,本文以 Google 為例介紹如何使用 Vue 實現授權登錄。
npm install vue-google-oauth2
安裝好依賴之后,在需要使用授權登錄的地方導入配置。
import Vue from 'vue'
import GAuth from 'vue-google-oauth2'
const gauthOption = {
clientId: 'YOUR_CLIENT_ID.apps.googleusercontent.com',
scope: 'profile email',
prompt: 'select_account'
}
Vue.use(GAuth, gauthOption)
以上代碼即為配置授權登錄的代碼,在客戶端需要進行登錄操作時,我們需要使用 GAuth 插件提供的 login 等方法。
this.$gAuth.signIn()
this.$gAuth.signOut()
以上代碼即為在客戶端進行登錄或注銷操作時需要使用的代碼。
那么,在后端如何處理授權登錄呢?我們需要在后端創建一個接口用于處理授權登錄過程,并將其與前端進行數據交互。
//在 router.js 中定義接口
const express = require('express')
const passport = require('passport')
const GoogleStrategy = require('passport-google-oauth20').Strategy
const app = express()
app.use(passport.initialize())
passport.use(new GoogleStrategy({
clientID: "YOUR_CLIENT_ID",
clientSecret: "YOUR_CLIENT_SECRET",
callbackURL: "http://localhost:3000/login/google/callback"
},
function(accessToken, refreshToken, profile, done) {
return done(null, profile)
}
))
app.get('/login/google', passport.authenticate('google', { scope: ['profile', 'email'] }));
app.get('/login/google/callback',
passport.authenticate('google', { failureRedirect: '/login' }),
function(req, res) {
res.redirect('/')
}
);
以上代碼即為后端處理 Google 授權登錄的示例代碼,其中需要替換為自己申請的 clientID 和 clientSecret,且 callbackURL 需要和前端設置的 redirect URI 保持一致。
通過上述前端和后端的代碼實現,我們即可實現 Vue 引入授權登錄的功能。