매개 변수를 받아 들일 수있는 미들웨어를 만들려고합니다. 어떻게 할 수 있습니까?
예
app.get('/hasToBeAdmin', HasRole('Admin'), function(req,res){
})
HasRole = function(role, req, res, next){
if(role != user.role){
res.redirect('/NotInRole);
}
next();
}
매개 변수를 받아 들일 수있는 미들웨어를 만들려고합니다. 어떻게 할 수 있습니까?
예
app.get('/hasToBeAdmin', HasRole('Admin'), function(req,res){
})
HasRole = function(role, req, res, next){
if(role != user.role){
res.redirect('/NotInRole);
}
next();
}
답변:
function HasRole(role) {
return function(req, res, next) {
if (role !== req.user.role) res.redirect(...);
else next();
}
}
또한 동일한 기능의 복사본을 여러 개 만들지 않았는지 확인하고 싶습니다.
function HasRole(role) {
return HasRole[role] || (HasRole[role] = function(req, res, next) {
if (role !== req.user.role) res.redirect(...);
else next();
})
}
app.get('/a', hasRole('admin'))
그리고 app.get('/b', hasRole('admin'))
각각의 새로운 클로저를 만들 것입니다 hasRole
. 정말 큰 응용 프로그램이 없다면 이것은 현실적으로 그다지 중요하지 않습니다. 나는 기본적으로 이렇게 코딩합니다.
app.get('/hasToBeAdmin', (req, res, next) => {
hasRole(req, res, next, 'admin');
}, (req,res) => {
// regular route
});
const hasRole = (req, res, next, role) => {
if(role != user.role){
res.redirect('/NotInRole');
}
next();
};
또는 케이스가 너무 많지 않거나 역할이 문자열이 아닌 경우 :
function HasRole(role) {
return function (req, res, next) {
if (role !== req.user.role) res.redirect(/* ... */);
else next();
}
}
var middlware_hasRoleAdmin = HasRole('admin'); // define router only once
app.get('/hasToBeAdmin', middlware_hasRoleAdmin, function (req, res) {
})
다양한 권한 수준이있는 경우 다음과 같이 구성 할 수 있습니다.
const LEVELS = Object.freeze({
basic: 1,
pro: 2,
admin: 3
});
/**
* Check if user has the required permission level
*/
module.exports = (role) => {
return (req, res, next) => {
if (LEVELS[req.user.role] < LEVELS[role]) return res.status(401).end();
return next();
}
}
이 솔루션을 사용합니다. body req에서 jwt 토큰을 받고 거기에서 역할 정보를 얻습니다.
//roleMiddleware.js
const checkRole = role => {
return (req, res, next) => {
if (req.role == role) {
console.log(`${role} role granted`)
next()
} else {
res.status(401).send({ result: 'error', message: `No ${role} permission granted` })
}
}
}
module.exports = { checkRole }
그래서 먼저 인증 미들웨어를 사용하여 유효한 사용자인지 확인한 다음 역할 미들웨어를 사용하여 사용자가 api 경로에 액세스 할 수 있는지 확인합니다.
// router.js
router.post('/v1/something-protected', requireAuth, checkRole('commercial'), (req, res) => {
// do what you want...
})
도움이 되길 바랍니다