Express + Node.js實現(xiàn)登錄攔截器的實例代碼
介紹
這邊的攔截器,對應于spring MVC中的filter,所有的http請求,通過攔截器處理之后才能訪問到對應的代碼/資源。
最典型的應用場景就是實現(xiàn)訪問權(quán)限控制,給予不同的用戶/用戶組不同的頁面和接口訪問權(quán)限,僅能夠訪問允許的頁面和接口。
場景
app.post('/login', function(request, res, next){ // do something }); app.post('/getData',function(request, res, next){ // do something var data="some data"; res.send({"data":data}); });
如果不做任何處理,任何人發(fā)送getData的post請求可以直接從后臺讀取數(shù)據(jù),而不需要任何的登陸,只需要知道接口就可以。
對應每個接口,如果在每個接口下面加上權(quán)限判斷,代碼會非常的重復,于是面向切面就來了,可以通過把攔截器加在每個http請求之前,來實現(xiàn)權(quán)限判斷的功能。
實現(xiàn)
// 所有用戶可以訪問index.html, error.html // admin可以訪問admin.html, /getData // 登陸用戶可以訪問home.html app.all('/*', function(request, res, next){ // 思路: // 得到請求的url // 然后得到request的cookie,根據(jù)cookie得到當前登陸的用戶 // 判斷用戶對應url的權(quán)限 var jsPattern=/\.js$/; var url=request.orignalUrl; if(jsPattern.test(url)){ // 公共部分,放行 next(); return; } if(url=='index.html'||url=='error.html'){ next(); return; } var cookie=JSON.stringify(req.cookies); if(access){ next(); } else{ res.redirect('error.html'); } });
實現(xiàn)思路:
1. 攔截所有請求(上面的就可以啦),得到當前訪問的url
2. 根據(jù)cookie得到當前用戶
3. 根據(jù)url和用戶對應的身份來判斷是否可以訪問
4. 如果可以調(diào)用next();
5. 如果不能訪問,返回錯誤信息
注意
- next(); 僅僅是一個函數(shù),對應著原本處理請求的代碼,如前面的app.post(‘/getData'),當這里的代碼處理完成后會回到對應next(); 處,所以需要處理好對應的關(guān)系,如果必要需要return結(jié)束當前的函數(shù),不然會出錯噠。
- 對于公共的部分,如js插件,部分圖片,還有css的部分,可以直接放行。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
node.js三個步驟實現(xiàn)一個服務器及Express包使用
這篇文章主要介紹了node.js三個步驟實現(xiàn)一個服務器及Express包使用,文章通過新建一個文件展開全文內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下2022-05-05Node.js中的EventEmitter類使用小結(jié)
EventEmitter 是 Node.js 中的一個核心模塊,它提供了一種實現(xiàn)事件驅(qū)動編程的機制,它是一個基于觀察者模式的類,用于在應用程序中處理事件和觸發(fā)事件,這篇文章主要介紹了Node.js中的EventEmitter類介紹,需要的朋友可以參考下2023-12-12