leancloud用戶系統

對于nodejs開發者來說,可能會發現leancloud有兩個給js使用的sdk:leanengine-node-sdkjavascript-sdk
前者的npm包名是leanengine,后者包名叫做avoscloud-sdk。
看一下leanengine的package.json可以發現


leanengine是依賴avoscloud-sdk的,leanengine除了能夠使用avoscloud-sdk的全部功能以外,還有額外拓展的供nodejs使用的方法。

所以結論就是,如果是一個純前端的項目,就引入avoscloud-sdk,而如果使用在nodejs服務器的話,則引入leanengine。之前有一個項目在(我猜是因為)前端使用了leanengine,會使chrome產生websocket連接的問題,而導致瀏覽器卡死。
用戶

在leancloud新建的項目,會有6個默認的Class,這篇文章會說到其中的_User

_User表的字段如下:


其中username和password是必填字段,而且username是一個要求唯一的字段。email和mobilePhoneNumber則是選填字段。

authData用來保存第三方登錄信息,也是本文后面重點要說的部分。

emailVerified和mobilePhoneVerified是布爾型,用來標注郵箱和手機是否驗證。順便一提,郵箱驗證和手機驗證服務已經集成在leancloud內了,不需要使用額外的郵件或短信服務商,而且驗證后直接更新數據庫,完全沒有開發的成本。

sessionToken字段是記錄用戶會話的,在avoscloud-sdk 0.5.1版本中,加入了AV.User.become方法,可以使用sessionToken直接登錄。

注冊 AV.User.signUp()

LeanCloud 文檔
標注的注冊方法需要用戶名和密碼,其他信息可以隨注冊信息一起提供,或者在signUp的回調中再次更新。

登錄 AV.User.logIn()

LeanCloud 文檔
leancloud的標準登錄方法除了支持username和password登錄,同時支持email和password登錄。這也就是說,郵箱登陸的功能也不需要額外開發了,可以直接在登錄框位置注明:“用戶名/郵箱” 然后無論用戶輸入的是username還是email,都可以用logIn方法登入。

如果要使用手機登錄,則要調用AV.User.logInWithMobilePhone()方法,另一種手機登錄方式是通過手機號和驗證短信直接登入的AV.User.requestSmsCode(),如果使用這個方法注冊的話,新用戶的username默認為手機號碼。

綁定第三方

LeanCloud 文檔**
AV.User._logInWith()方法提供了第三方綁定的方法。這個方法會創建一個新的用戶,username為隨機串。

綁定微博的代碼是:

AV.User._logInWith('weibo', { 
    'authData': {
        'uid': '123456789', 
        'access_token': '2.00vs3XtCI5FevCff4981adb5jj1lXE', 'expiration_in': '36000' 
    }
}).then(function(user) { 
    //返回綁定后的用戶 
    console.log(user);
},
function(error) { 
    console.log(error);
});

綁定github可以用:

AV.User._logInWith('github',{ 
    "authData":{ 
        'uid': uid, 
        'access_token': access_token 
    }
}).then(function(user) { 
    console.log(user)
}, 
function(error) { 
    console.log(error);
});

其中微博,微信和QQ,leancloud會在登錄時驗證access_token的可靠性,其他第三方平臺要自行通過平臺的方法去驗證。
如果已經有一個leancloud賬號,想要綁定第三方,可以使用_linkWith方法

var user = ...已存在的處于登錄狀態的 AV.User 對象 ...
user._linkWith('weibo', { 
    'authData': { 
        'uid': '123456789', 
        'access_token': '2.00vs3XtCI5FevCff4981adb5jj1lXE', 
        'expiration_in': '36000' 
    }
}).then(function(user) { 
    console.log(user);
}, function(error) { 
    console.log(error);
});

這里leancloud不會驗證這個第三方賬號是不是已經被其他用戶綁定,如果同一個微博賬號多次綁定用戶,代碼執行的時候不會報錯,在登錄的時候,會登入最后一個綁定的賬號。

當前用戶

通過AV.User.current()方法可以得到當前登錄的用戶。這里面就要說一下前端登錄和后端登錄的關系。

后端登錄和前端是分開的,比如做第三方登錄的時候,第三方都需要一個回調地址,那么我們可以在這個回調的路由中處理accesstoken的驗證,然后(也必須)在后端完成登錄。這個部分不能做在前端,因為驗證accesstoken需要第三方的appid和secretid,secretid是不能夠暴露在前端的。

那么在后端調用了比如AV.User._logInWith()方法完成登錄之后,同樣可以用AV.User.current()取到用戶信息。

leancloud提供了session和cookie管理的中間件

app.use(AV.Cloud.CookieSession({ secret: 'xitusecretxxxx', maxAge: 3600000, fetchUser: false }));
引入這個中間件之后,當后臺登錄,前端請求的頁面都會帶有一個cookie(截圖是未登錄狀態)

cookie的默認名是avos:sess
注意這個cookie是而且只能是httpOnly的。
當頁面發出HTTP請求到路由(以express代碼為例)

function adminIsLoggedIn(req, res, next) { 
    var user = req.AV.user; 
    if(!user) 
        return res.redirect('/'); 
    var query = new AV.Query(AV.Role);
    query.equalTo('users', user); 
    query.equalTo('name', "admin"); 
    query.count().then(function(count){ 
        if(count) { 
            return next(); 
        } 
        else
            { 
                return res.redirect('/'); 
            } 
        }, function(error) { 
            return res.redirect('/'); 
        });
}
app.get('/admin', adminIsLoggedIn, admin.home);

req.AV.user能夠得到當前session中的user對象,從而進行身份驗證。leancloud官方不建議在這里使用AV.User.Current(),因為這個函數使用了Domain。另外要注意的是,如果僅僅使用了前端登錄,那么雖然在前端可以AV.User.Current()拿到user,但是req.AV.user依然是空的。

前端登錄就比較簡單了,同樣調用登錄函數,leancloud會把個人信息放在localstorage里面


然后前端調用AV.User.current()就可以取到當前的的用戶信息。

一般的應用應該使用后端登錄的方式,而如果是微信移動端或者是SPA的應用,可以考慮前端登錄方式。

OAuth2

既然前面說到了第三方登錄,順便說說OAuth2。

一個比較通用的OAuth2過程如上圖所示,不同平臺的參數個數和參數名可能略有不同,就把幾個重要的參數拿出來說明一下。

首先是請求授權頁面,需要第三方平臺的appid,回調地址要提前在第三方注冊,scope是請求的權限,state是可以在授權成功之后返回的參數。

授權成功之后,返回授權頁面,可以通過傳入的state來決定不同的方式,比如多個平臺共用一個回調地址的時候,可以通過state參數來判斷code所屬平臺,然后調用對應平臺的驗證API。

通過code換取access_token這一步必須要在后臺完成,因為涉及到使用appsecret,不能暴露在前端。
得到access_token之后,就可以為所欲為的拿用戶各種數據啦。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,527評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,687評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,640評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,957評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,682評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,011評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,009評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,183評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,714評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,435評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,665評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,148評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,838評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,251評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,588評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,379評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,627評論 2 380

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,765評論 25 708
  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,830評論 18 139
  • REST API 可以讓你用任何支持發送 HTTP 請求的設備來與 Parse 進行交互,你可以使用 REST A...
    Caroline嗯哼閱讀 2,052評論 0 0
  • 守衛懶洋洋的打了個哈欠,眼皮越來越重,倚著槍睡著了。 瞌睡蟲是仙蟲,能讓普通法力的仙人睡上兩個時辰。天上一日,相當...
    柳汀雪閱讀 328評論 0 1
  • 時值寒冬,郊外是一片荒嶺。這山上也沒有梅花,自然也不會有踏雪尋梅的風雅。風瑟瑟地吹著,直刺心骨;湖面都結了...
    寒江三月閱讀 214評論 0 0